# TMC5160 / TMC5160A DATASHEET

Universal high voltage controller/driver for two-phase bipolar stepper motor. StealthChop™ for quiet movement. External MOSFETs for up to 20A motor current per coil. With Step/Dir Interface and SPI.



#### FEATURES AND BENEFITS

2-phase stepper motors up to 20A coil current (external MOSFETs) Motion Controller with SixPoint<sup>™</sup> ramp Step/Dir Interface with microstep interpolation MicroPlyer™ Voltage Range 8 ... 60V DC SPI & Single Wire UART Encoder Interface and 2x Ref.-Switch Input Highest Resolution 256 microsteps per full step StealthChop2<sup>™</sup> for quiet operation and smooth motion **Resonance Dampening** for mid-range resonances spreadCycle<sup>™</sup> highly dynamic motor control chopper dcStep<sup>™</sup> load dependent speed control StallGuard2<sup>™</sup> high precision sensorless motor load detection CoolStep™ current control for energy savings up to 75% Passive Braking and freewheeling mode **Full Protection & Diagnostics** Compact Size 7x7mm<sup>2</sup> (body) TQFP48 package / 8x8mm<sup>2</sup> QFN

#### DESCRIPTION

The TMC5160 / TMC5160A is a high-power stepper motor controller and driver IC with serial communication interfaces. It combines a flexible ramp generator for automatic target positioning with industries' most advanced stepper motor driver. Using external transistors, highly dynamic, high torque drives can be realized. Based on TRINAMICs sophisticated SpreadCycle and StealthChop choppers, the driver ensures absolutely noiseless operation combined with maximum efficiency and best motor torque. High integration, high energy efficiency and a small form factor enable miniaturized and scalable systems for cost effective solutions. The complete solution reduces learning curve to a minimum while giving best performance in class.

MOTTON CONTROL



WW.SKYTECH.IR

#### BLOCK DIAGRAM

Hamburg. Germany

published by

#### APPLICATION EXAMPLES: HIGH VOLTAGE – MULTIPURPOSE USE

The TMC5160 scores with complete motion controlling features, powerful external MOSFET driver stages, and high-quality current regulation. It offers a versatility that covers a wide spectrum of applications from battery powered, high efficiency systems up to embedded applications with 20A motor current per coil. The TMC5160 contains the complete intelligence which is required to drive a motor. Receiving target positions, the TMC5160 manages motor movement. Based on TRINAMICs unique features StallGuard2, CoolStep, DcStep, SpreadCycle, and StealthChop, it optimizes drive performance. It trades off velocity vs. motor torque, optimizes energy efficiency, smoothness of the drive, and noiselessness. The small form factor of the TMC5160 keeps costs down and allows for miniaturized layouts. Extensive support at the chip, board, and software levels enables rapid design cycles and fast time-to-market with competitive products. High energy efficiency and reliability deliver cost savings in related systems such as power supplies and cooling. For smaller designs, the compatible, integrated TMC5130 driver provides 1.4A of motor current.

MINIATURIZED DESIGN FOR ONE STEPPER MOTOR



#### **ORDER CODES**

| Order code     | PN      | Description                                             | Size [mm <sup>2</sup> ] |
|----------------|---------|---------------------------------------------------------|-------------------------|
| TMC5160A-TA    | 00-0179 | stepper controller/driver for external MOSFETs; TQFP48  | 7 x 7 (body)            |
| TMC5160A-WA    | 00-0192 | stepper controller/driver f. ext. MOSFETs; wett. QFN8x8 | 8 x 8                   |
| TMC5160A-xx-T  | T       | -T denotes tape on reel packing (xx= TA or WA)          |                         |
| TMC5160-EVAL   | 40-0138 | Evaluation board for TMC5160 (/A)                       | 85 x 55                 |
| LANDUNGSBRÜCKE | 40-0167 | Baseboard for TMC5160-EVAL and further boards.          | 85 x 55                 |
| ESELSBRÜCKE    | 40-0098 | Connector board fitting to Landungsbrücke               | 61 x 38                 |

*Hint*: TMC5160 in this manual always refers to both, the TMC5160A and TMC5160, unless explicitly noted with "non-A-version" or "A-version". The A-version compatibly replaces the non-A-version.

# **Table of Contents**

| 1 | PRI                                                                                                                    | NCIPLES OF OPERATION                                              | 5                                                                                          |
|---|------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
|   | 1.1                                                                                                                    | Key Concepts                                                      | 6                                                                                          |
|   | 1.2                                                                                                                    | CONTROL INTERFACES                                                |                                                                                            |
|   | 1.3<br>1.4                                                                                                             | SOFTWARE                                                          | •                                                                                          |
|   | 1.4<br>1.5                                                                                                             | AUTOMATIC STANDSTILL POWER DOWN                                   | -                                                                                          |
|   | 1.6                                                                                                                    | STEALTHCHOP2 & SPREADCYCLE DRIVER                                 |                                                                                            |
|   | 1.7                                                                                                                    | STALLGUARD2 – MECHANICAL LOAD SENSING                             |                                                                                            |
|   | 1.8<br>CONTRO                                                                                                          | COOLSTEP – LOAD ADAPTIVE CURRENT                                  |                                                                                            |
|   | 1.9                                                                                                                    | DCSTEP - LOAD DEPENDENT SPEED CONTROL                             | •                                                                                          |
|   | 1.10                                                                                                                   | ENCODER INTERFACE                                                 |                                                                                            |
| 2 | PTN                                                                                                                    | ASSIGNMENTS                                                       | 1                                                                                          |
| - |                                                                                                                        |                                                                   |                                                                                            |
|   | 2.1<br>2.2                                                                                                             | PACKAGE OUTLINE                                                   |                                                                                            |
| 3 |                                                                                                                        | IPLE CIRCUITS                                                     |                                                                                            |
| - | 2.1                                                                                                                    | STANDARD APPLICATION CIRCUIT                                      | 5                                                                                          |
|   | 3.1<br>3.2                                                                                                             | EXTERNAL GATE VOLTAGE REGULATOR                                   |                                                                                            |
|   | 3.3                                                                                                                    | CHOOSING MOSFETS AND SLOPE                                        |                                                                                            |
|   | 3.4                                                                                                                    | TUNING THE MOSFET BRIDGE                                          |                                                                                            |
|   | 3.5                                                                                                                    | HIGHER VOLTAGE APPLICATIONS2                                      | 2                                                                                          |
| 4 | SPI                                                                                                                    | INTERFACE                                                         | 3                                                                                          |
|   | 4.1                                                                                                                    | SPI DATAGRAM STRUCTURE                                            | 3                                                                                          |
|   | 4.2                                                                                                                    | SPI SIGNALS                                                       | 4                                                                                          |
|   |                                                                                                                        |                                                                   | -                                                                                          |
|   | 4.3                                                                                                                    | TIMING                                                            |                                                                                            |
| 5 |                                                                                                                        |                                                                   |                                                                                            |
| 5 | UAR<br>5.1                                                                                                             | TIMING2<br><b>T SINGLE WIRE INTERFACE2</b><br>DATAGRAM STRUCTURE2 | <b>6</b>                                                                                   |
| 5 | UAR<br>5.1<br>5.2                                                                                                      | TIMING                                                            | <b>6</b><br>6<br>8                                                                         |
| 5 | UAR<br>5.1<br>5.2<br>5.3                                                                                               | TIMING                                                            | 6<br>6<br>8<br>8                                                                           |
| - | UAR<br>5.1<br>5.2<br>5.3<br>5.4                                                                                        | TIMING                                                            | <b>6</b><br>6<br>8<br>8<br>9                                                               |
| 5 | UAR<br>5.1<br>5.2<br>5.3<br>5.4<br>REG                                                                                 | TIMING                                                            | 6<br>8<br>8<br>9<br>1                                                                      |
| - | UAR<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1                                                                          | TIMING                                                            | 6<br>8<br>8<br>9<br>1                                                                      |
| - | UAR<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2                                                                   | TIMING                                                            | 6<br>8<br>8<br>9<br>1<br>2                                                                 |
| - | UAR<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2                                                                   | TIMING                                                            | 6<br>8<br>9<br>1<br>2<br>8                                                                 |
| - | UAR<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2<br>CONTRO<br>6.3<br>6.4                                           | TIMING                                                            | 6<br>8<br>9<br>1<br>2<br>8<br>0<br>5                                                       |
| - | UAR<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2<br>CONTRO<br>6.3<br>6.4<br>6.5                                    | TIMING                                                            | 6<br>8<br>9<br>1<br>2<br>8<br>0<br>5<br>7                                                  |
| - | UAR<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2<br>CONTRO<br>6.3<br>6.4<br>6.5                                    | TIMING                                                            | 6<br>8<br>9<br>1<br>2<br>8<br>0<br>5<br>7                                                  |
| 6 | UAF<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2<br>CONTRO<br>6.3<br>6.4<br>6.5<br>STE<br>7.1                      | TIMING                                                            | 6<br>8<br>9<br>1<br>2<br>8<br>0<br>5<br>7<br>7<br>7                                        |
| 6 | UAF<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2<br>CONTRO<br>6.3<br>6.4<br>6.5<br>STE<br>7.1<br>7.2               | TIMING                                                            | 6<br>8<br>8<br>9<br>1<br>2<br>8<br>0<br>5<br>7<br>7<br>0                                   |
| 6 | UAF<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2<br>CONTRO<br>6.3<br>6.4<br>6.5<br>STE<br>7.1<br>7.2<br>7.3        | TIMING                                                            | 6<br>8<br>9<br>1<br>2<br>8<br>0<br>5<br>7<br>7<br>0<br>0                                   |
| 6 | UAF<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2<br>CONTRO<br>6.3<br>6.4<br>6.5<br>STE<br>7.1<br>7.2               | TIMING                                                            | 6<br>8<br>9<br>1<br>2<br>8<br>0<br>5<br>7<br>7<br>0<br>0<br>3                              |
| 6 | UAF<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2<br>CONTRO<br>6.3<br>6.4<br>6.5<br>STE<br>7.1<br>7.2<br>7.3<br>7.4 | TIMING                                                            | <b>6</b><br>6<br>8<br>8<br>9<br><b>1</b><br>2<br>8<br>0<br>5<br>7<br>7<br>0<br>0<br>3<br>4 |
| 6 | UAF<br>5.1<br>5.2<br>5.3<br>5.4<br>REG<br>6.1<br>6.2<br>CONTRO<br>6.3<br>6.4<br>6.5<br>STE<br>7.1<br>7.2<br>7.3<br>7.4 | TIMING                                                            | <b>6</b><br>6889<br><b>1</b><br>28057<br><b>7</b><br>7003.46                               |

| 8   | SP         | READCYCLE AND CLASSIC CHOPPER                            | 68   |
|-----|------------|----------------------------------------------------------|------|
|     | 8.1<br>8.2 | SpreadCycle Chopper<br>Classic Constant Off Time Chopper |      |
| 9   | SE         | LECTING SENSE RESISTORS                                  | 74   |
| 10  |            | VELOCITY BASED MODE CONTROL                              | 76   |
| 11  |            | DIAGNOSTICS AND PROTECTION                               | 78   |
| -   | 11.1       | Temperature Sensors                                      | 78   |
| 2   | 11.2       | SHORT PROTECTION                                         | 78   |
| 2   | 11.3       | OPEN LOAD DIAGNOSTICS                                    | 80   |
| 12  |            | RAMP GENERATOR                                           | 81   |
|     | 12.1       | REAL WORLD UNIT CONVERSION                               | 81   |
| -   | 12.2       | MOTION PROFILES                                          | 82   |
| 1   | 12.3       | VELOCITY THRESHOLDS                                      |      |
| 1   | 12.4       | REFERENCE SWITCHES                                       | 85   |
| 13  |            | STALLGUARD2 LOAD MEASUREMENT                             | 87   |
| 1   | 13.1       | TUNING STALLGUARD2 THRESHOLD SGT.                        |      |
|     | 13.2       | STALLGUARD2 UPDATE RATE AND FILTER                       |      |
|     | 13.3       | DETECTING A MOTOR STALL                                  |      |
|     | 13.4       | HOMING WITH STALLGUARD                                   |      |
| -   | 13.5       | LIMITS OF STALLGUARD2 OPERATION                          |      |
| 14  |            | COOLSTEP OPERATION                                       |      |
|     | 14.1       | USER BENEFITS                                            |      |
|     | 14.2       | SETTING UP FOR COOLSTEP                                  |      |
| -   | 14.3       | TUNING COOLSTEP                                          |      |
| 15  |            | STEP/DIR INTERFACE                                       |      |
|     | 15.1       |                                                          |      |
|     | 15.2       | CHANGING RESOLUTION                                      |      |
| 1   | 15.3       | MICROPLYER AND STAND STILL DETECTIO                      | N.96 |
| 16  |            | DIAG OUTPUTS                                             | 97   |
| -   | 16.1       | STEP/DIR Mode                                            | 97   |
| i i |            | MOTION CONTROLLER MODE                                   |      |
|     |            | DCSTEP                                                   |      |
|     | 17.1       | USER BENEFITS                                            | 99   |
| 1   | 17.2       | DESIGNING-IN DCSTEP                                      | 99   |
|     |            | DCSTEP INTEGRATION WITH THE MOTION                       |      |
|     |            | ROLLER                                                   |      |
|     |            | STALL DETECTION IN DCSTEP MODE                           |      |
|     |            | MEASURING ACTUAL MOTOR VELOCITY IN<br>EP OPERATION       |      |
|     |            | DCSTEP WITH STEP/DIR INTERFACE                           |      |
|     | -          | SINE-WAVE LOOK-UP TABLE                                  |      |
|     | 18 1       | USER BENEFITS                                            | 105  |
|     | 18.2       |                                                          |      |
| 19  |            | EMERGENCY STOP                                           | 106  |

F

#### 20 ABN INCREMENTAL ENCODER

| IN | ITER         | FACE                          | 107 |
|----|--------------|-------------------------------|-----|
|    | 20.2         |                               | R   |
|    | RESO<br>20.3 | LUTION<br>CLOSING THE LOOP    |     |
|    |              |                               |     |
| 21 | L            | DC MOTOR OR SOLENOID          | 110 |
|    | 21.1         | SOLENOID OPERATION            | 110 |
| 22 | 2            | QUICK CONFIGURATION GUIDE     | 111 |
| 23 | 3            | GETTING STARTED               | 116 |
|    | 23.1         | INITIALIZATION EXAMPLES       | 116 |
| 2/ |              | STANDALONE OPERATION          | 117 |
| 25 | 5            | EXTERNAL RESET                | 119 |
| 26 | 5            | CLOCK OSCILLATOR AND INPUT    | 119 |
|    | 26.1         | USING THE INTERNAL CLOCK      | 119 |
|    | 26.2         | USING AN EXTERNAL CLOCK       | 119 |
| 27 | 7            | ABSOLUTE MAXIMUM RATINGS      | 120 |
| 28 | 3            | ELECTRICAL CHARACTERISTICS    | 120 |
|    | 28.1         |                               |     |
|    | 28.2         | DC AND TIMING CHARACTERISTICS | 121 |

| 28.3 | 3 THERMAL CHARACTERISTICS      | 123 |
|------|--------------------------------|-----|
| 29   | LAYOUT CONSIDERATIONS          | 125 |
| 29.1 | L EXPOSED DIE PAD              | 125 |
| 29.2 | 2 WIRING GND                   | 125 |
| 29.3 | 3 WIRING BRIDGE SUPPLY         | 125 |
| 29.4 | SUPPLY FILTERING               | 125 |
| 29.5 | 5 LAYOUT EXAMPLE               | 126 |
| 30   | PACKAGE MECHANICAL DATA        | 128 |
| 30.1 | DIMENSIONAL DRAWINGS TQFP48-EP | 128 |
| 30.2 | 2 DIMENSIONAL DRAWINGS QFN-WA  | 130 |
| 30.3 | B PACKAGE CODES                | 131 |
| 31   | DESIGN PHILOSOPHY              |     |
| 32   | DISCLAIMER                     | 132 |
| 33   | ESD SENSITIVE DEVICE           | 132 |
| 34   | DESIGNED FOR SUSTAINABILITY    | 132 |
| 35   | TABLE OF FIGURES               | 133 |
| 36   | REVISION HISTORY               | 134 |
| 37   | REFERENCES                     | 134 |

# SKYTECH

www.trinamic.com

### **1** Principles of Operation

The TMC5160 motion controller and driver chip is an intelligent power component interfacing between CPU and a high power stepper motor. All stepper motor logic is completely within the TMC5160. No software is required to control the motor – just provide target positions. The TMC5160 offers a number of unique enhancements which are enabled by the system-on-chip integration of driver and controller. The SixPoint ramp generator of the TMC5160 uses StealthChop, DcStep, CoolStep, and StallGuard2 automatically to optimize every motor movement. The TMC5160 ideally extends the TMC2100, TMC2130 and TMC5130 family to higher voltages and higher motor currents.

#### THE TMC5160 OFFERS THREE BASIC MODES OF OPERATION:

#### **MODE 1: Full Featured Motion Controller & Driver**

All stepper motor logic is completely within the TMC5160. No software is required to control the motor – just provide target positions. Enable this mode by tying low pin SD\_MODE.

#### MODE 2: Step & Direction Driver

An external high-performance S-ramp motion controller like the TMC4361 or a central CPU generates step & direction signals synchronized to other components like additional motors within the system. The TMC5160 takes care of intelligent current and mode control and delivers feedback on the state of the motor. The MicroPlyer automatically smoothens motion. Tie SD\_MODE high.

#### MODE 3: Simple Step & Direction Driver

The TMC5160 positions the motor based on step & direction signals. The MicroPlyer automatically smoothens motion. No CPU interaction is required; configuration is done by hardware pins. Basic standby current control can be done by the TMC5160. Optional feedback signals allow error detection and synchronization. Enable this mode by tying pin SPI MODE low and SD MODE high.



Figure 1.1 TMC5160 basic application block diagram (motion controller)

www.trinamic.com

5



Figure 1.3 TMC5160 standalone driver application diagram

### 1.1 Key Concepts

The TMC5160 implements advanced features which are exclusive to TRINAMIC products. These features contribute toward greater precision, greater energy efficiency, higher reliability, smoother motion, and cooler operation in many stepper motor applications.

www.trinamic.com

| StealthChop2™ | No-noise, high-precision chopper algorithm for inaudible motion and inaudible standstill of the motor. Allows faster motor acceleration and deceleration than StealthChop™ and extends StealthChop to low stand still motor currents. |  |  |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| SpreadCycle™  | High-precision chopper algorithm for highly dynamic motion and absolutely clean current wave. Low noise, low resonance and low vibration chopper.                                                                                     |  |  |  |  |
| DcStep™       | Load dependent speed control. The motor moves as fast as possible and never loses a step.                                                                                                                                             |  |  |  |  |
| StallGuard2™  | Sensorless stall detection and mechanical load measurement.                                                                                                                                                                           |  |  |  |  |
| CoolStep™     | Load-adaptive current control reducing energy consumption by as much as 75%.                                                                                                                                                          |  |  |  |  |
| MicroPlyer™   | Microstep interpolator for obtaining full 256 microstep smoothness with lower resolution step inputs starting from fullstep                                                                                                           |  |  |  |  |

In addition to these performance enhancements, TRINAMIC motor drivers offer safeguards to detect and protect against shorted outputs, output open-circuit, overtemperature, and undervoltage conditions for enhancing safety and recovery from equipment malfunctions.

### **1.2** Control Interfaces

The TMC5160 supports both, an SPI interface and a UART based single wire interface with CRC checking. Additionally, a standalone mode is provided for pure STEP/DIR operation without use of the serial interface. Selection of the actual interface is done via the configuration pins SPI\_MODE and SD\_MODE, which can be hardwired to GND or VCC\_IO depending on the desired interface.

#### 1.2.1 SPI Interface

The SPI interface is a bit-serial interface synchronous to a bus clock. For every bit sent from the bus master to the bus slave another bit is sent simultaneously from the slave to the master. Communication between an SPI master and the TMC5160 slave always consists of sending one 40-bit command word and receiving one 40-bit status word.

The SPI command rate typically is a few commands per complete motor motion.

### 1.2.2 UART Interface

The single wire interface allows differential operation similar to RS485 (using SWP and SWN) or single wire interfacing (leaving open SWN). It can be driven by any standard UART. No baud rate configuration is required.

### 1.3 Software

From a software point of view the TMC5160 is a peripheral with a number of control and status registers. Most of them can either be written only or read only. Some of the registers allow both read and write access. In case read-modify-write access is desired for a write only register, a shadow register can be realized in master software.

#### www.trinamic.com

### 1.4 Moving and Controlling the Motor

### **1.4.1** Integrated Motion Controller

The integrated 32 bit motion controller automatically drives the motor to target positions, or accelerates to target velocities. All motion parameters can be changed on the fly. The motion controller recalculates immediately. A minimum set of configuration data consists of acceleration and deceleration values and the maximum motion velocity. A start and stop velocity is supported as well as a second acceleration and deceleration setting. The integrated motion controller supports immediate reaction to mechanical reference switches and to the sensorless stall detection StallGuard2.

#### Benefits are:

- Flexible ramp programming
- Efficient use of motor torque for acceleration and deceleration allows higher machine throughput
- Immediate reaction to stop and stall conditions

### 1.4.2 STEP/DIR Interface

The motor can optionally be controlled by a step and direction input. In this case, the motion controller remains unused. Active edges on the STEP input can be rising edges or both rising and falling edges as controlled by another mode bit (*dedge*). Using both edges cuts the toggle rate of the STEP signal in half, which is useful for communication over slow interfaces such as optically isolated interfaces. On each active edge, the state sampled from the DIR input determines whether to step forward or back. Each step can be a fullstep or a microstep, in which there are 2, 4, 8, 16, 32, 64, 128, or 256 microsteps per fullstep. A step impulse with a low state on DIR increases the microstep counter and a high decreases the counter by an amount controlled by the microstep resolution. An internal table translates the counter value into the sine and cosine values which control the motor current for microstepping.

### 1.5 Automatic Standstill Power Down

An automatic current reduction drastically reduces application power dissipation and cooling requirements. Modify stand still current, delay time and decay via register settings. Automatic freewheeling and passive motor braking are provided as an option for stand still. Passive braking reduces motor standstill power consumption to zero, while still providing effective dampening and braking! An option for faster detection of standstill is provided for both, ramp generator and STEP/DIR operation.





### 1.6 StealthChop2 & SpreadCycle Driver

StealthChop is a voltage chopper based principle. It especially guarantees that the motor is absolutely quiet in standstill and in slow motion, except for noise generated by ball bearings. Unlike other voltage mode choppers, StealthChop2 does not require any configuration. It automatically learns the best settings during the first motion after power up and further optimizes the settings in subsequent motions. An initial homing sequence is sufficient for learning. Optionally, initial learning parameters

www.trinamic.com

can be pre-configured via the interface. StealthChop2 allows high motor dynamics, by reacting at once to a change of motor velocity.

For highest dynamic applications, SpreadCycle is an option to StealthChop2. It can be enabled via input pin (standalone mode) or via SPI or UART interface. StealthChop2 and SpreadCycle may even be used in a combined configuration for the best of both worlds: StealthChop2 for no-noise stand still, silent and smooth performance, SpreadCycle at higher velocity for high dynamics and highest peak velocity at low vibration.

SpreadCycle is an advanced cycle-by-cycle chopper mode. It offers smooth operation and good resonance dampening over a wide range of speed and load. The SpreadCycle chopper scheme automatically integrates and tunes fast decay cycles to guarantee smooth zero crossing performance.

#### Benefits of using StealthChop2:

- Significantly improved microstepping with low cost motors
- Motor runs smooth and quiet
- Absolutely no standby noise
- Reduced mechanical resonance yields improved torque

### 1.7 StallGuard2 – Mechanical Load Sensing

StallGuard2 provides an accurate measurement of the load on the motor. It can be used for stall detection as well as other uses at loads below those which stall the motor, such as CoolStep load-adaptive current reduction. This gives more information on the drive allowing functions like sensorless homing and diagnostics of the drive mechanics.

### 1.8 CoolStep – Load Adaptive Current Control

CoolStep drives the motor at the optimum current. It uses the StallGuard2 load measurement information to adjust the motor current to the minimum amount required in the actual load situation. This saves energy and keeps the components cool.

#### Benefits are:

- Energy efficiency power consumption decreased up to 75%
- Motor generates less heat improved mechanical precision
- Less or no cooling improved reliability
- Use of smaller motor
- less torque reserve required ightarrow cheaper motor does the job

Figure 1.5 shows the efficiency gain of a 42mm stepper motor when using CoolStep compared to standard operation with 50% of torque reserve. CoolStep is enabled above 60RPM in the example.



Figure 1.5 Energy efficiency with CoolStep (example)

www.trinamic.com

### 1.9 DcStep – Load Dependent Speed Control

DcStep allows the motor to run near its load limit and at its velocity limit without losing a step. If the mechanical load on the motor increases to the stalling load, the motor automatically decreases velocity so that it can still drive the load. With this feature, the motor will never stall. In addition to the increased torque at a lower velocity, dynamic inertia will allow the motor to overcome mechanical overloads by decelerating. DcStep directly integrates with the ramp generator, so that the target position will be reached, even if the motor velocity needs to be decreased due to increased mechanical load. A dynamic range of up to factor 10 or more can be covered by DcStep without any step loss. By optimizing the motion velocity in high load situations, this feature further enhances overall system efficiency.

#### Benefits are:

- Motor does not loose steps in overload conditions
- Application works as fast as possible
- Highest possible acceleration automatically
- Highest energy efficiency at speed limit
- Highest possible motor torque using fullstep drive
- Cheaper motor does the job

### **1.10 Encoder Interface**

The TMC5160 provides an encoder interface for external incremental encoders. The encoder provides automatic checking for step loss and can be used for homing of the motion controller (alternatively to reference switches). A programmable prescaler allows the adaptation of the encoder resolution to the motor resolution. A 32 bit encoder counter is provided.



www.trinamic.com

### 2 Pin Assignments

### 2.1 Package Outline



Figure 2.1 TMC5160-TA package and pinning TQFP-EP 48 (7x7mm<sup>2</sup> body, 9x9mm<sup>2</sup> with leads)



Figure 2.2 TMC5160-WA package and pinning QFN-WA (8x8mm<sup>2</sup>)

www.trinamic.com

### 2.2 Signal Descriptions

| Pin       | TQFP      | QFN        | Туре | Function                                                                                                                                                                                                                                                                                                                                                                    |
|-----------|-----------|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HB1       | 1         | 2          |      | High side gate driver output.                                                                                                                                                                                                                                                                                                                                               |
| CB1       | 2         | 3          |      | Bootstrap capacitor positive connection.                                                                                                                                                                                                                                                                                                                                    |
| 12VOUT    | 3         | 4          |      | Output of internal 11.5V gate voltage regulator and supply pin<br>of low side gate drivers. Attach $2.2\mu$ F to $10\mu$ F ceramic<br>capacitor to GND plane near to pin for best performance. Use<br>at least 10 times more capacity than for bootstrap capacitors.<br>In case an external gate voltage supply is available, tie VSA<br>and 12VOUT to the external supply. |
| VSA       | 4         | 5          |      | Analog supply voltage for 11.5V and 5V regulator. Normally tied to VS. Provide a 100nF filtering capacitor.                                                                                                                                                                                                                                                                 |
| 5VOUT     | 5         | 6          |      | Output of internal 5V regulator. Attach $2.2\mu$ F to $10\mu$ F ceramic capacitor to GNDA near to pin for best performance. Output for VCC supply of the chip.                                                                                                                                                                                                              |
| GNDA      | 6         | 7          |      | Analog GND. Connect to GND plane near pin.                                                                                                                                                                                                                                                                                                                                  |
| SRAL      | 7         | 8          | AI   | Sense resistor GND connection for phase A. Connect to the GND side of the sense resistor in order to compensate for voltage drop on the GND interconnection.                                                                                                                                                                                                                |
| SRAH      | 8         | 9          | AI   | Sense resistor for phase A. Connect to the upper side of the<br>sense resistor. A Kelvin connection is preferred with high<br>motor currents. Symmetrical RC-Filtering may be added for<br>SRAL and SRAH to eliminate high frequency switching spikes<br>from other drives or switching of coil B.                                                                          |
| SRBH      | 9         | 10         | AI   | Sense resistor for phase B. Connect to the upper side of the<br>sense resistor. A Kelvin connection is preferred with high<br>motor currents. Symmetrical RC-Filtering may be added for<br>SRBL and SRBH to eliminate high frequency switching spikes<br>from other drives or switching of coil A.                                                                          |
| SRBL      | 10        | 11         | AI   | Sense resistor GND connection for phase B. Connect to the GND side of the sense resistor in order to compensate for voltage drop on the GND interconnection.                                                                                                                                                                                                                |
| TST_MODE  | 11        | 12         | DI   | Test mode input. Tie to GND using short wire.                                                                                                                                                                                                                                                                                                                               |
| CLK       | 12        | 13         | DI   | CLK input. Tie to GND using short wire for internal clock or<br>supply external clock. Internal clock-fail over circuit protects<br>against loss of external clock signal.                                                                                                                                                                                                  |
| CSN_CFG3  | 13        | 14         | DI   | SPI chip select input (negative active) (SPI_MODE=1) or<br>Configuration input (SPI_MODE=0)                                                                                                                                                                                                                                                                                 |
| SCK_CFG2  | 14        | 15         | DI   | SPI serial clock input (SPI_MODE=1) or<br>Configuration input (SPI_MODE=0)                                                                                                                                                                                                                                                                                                  |
| SDI_CFG1  | 15        | 16         | DI   | SPI data input (SPI_MODE=1) or<br>Configuration input (SPI_MODE=0) or<br>Next address input (NAI) for single wire interface.                                                                                                                                                                                                                                                |
| SDO_CFG0  | 16        | 17         | DIO  | SPI data output (tristate) (SPI_MODE=1) or<br>Configuration input (SPI_MODE=0) or<br>Next address output (NAO) for single wire interface.                                                                                                                                                                                                                                   |
| REFL_STEP | 17        | 18         | DI   | Left reference input (for internal ramp generator) or STEP input when (SD_MODE=1).                                                                                                                                                                                                                                                                                          |
| REFR_DIR  | 18        | 19         | DI   | Right reference input (for internal ramp generator) or DIR input (SD_MODE=1).                                                                                                                                                                                                                                                                                               |
| GNDD      | 19,<br>30 | 25,<br>Pad |      | Digital GND. Connect to GND plane near pin.                                                                                                                                                                                                                                                                                                                                 |
| VCC_IO    | 20        | 20         |      | 3.3V to 5V IO supply voltage for all digital pins.                                                                                                                                                                                                                                                                                                                          |

www.trinamic.com

| Pin                | TQFP | QFN | Туре               | Function                                                                                                                                                                                                                                                                                                                                                               |
|--------------------|------|-----|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SD_MODE            | 21   | 21  | DI                 | Mode selection input. When tied low, the internal ramp generator generates step pulses. When tied high, the STEP/DIR inputs control the driver. SD_MODE=0 and SPI_MODE=0 enable UART operation.                                                                                                                                                                        |
| SPI_MODE           | 22   | 22  | DI<br>(pd)         | Mode selection input. When tied low with SD_MODE=1, the chip is in standalone mode and pins have their CFG functions. When tied high, the SPI interface is enabled. Integrated pull down resistor.                                                                                                                                                                     |
| ENCB_DCEN_<br>CFG4 | 23   | 23  | DI<br>(pd)         | Encoder B-channel input (when using internal ramp generator)<br>or<br>DcStep enable input (SD_MODE=1, SPI_MODE=1) – leave open<br>or tie to GND for normal operation in this mode (no DcStep).<br>Configuration input (SPI_MODE=0)                                                                                                                                     |
| ENCA_DCIN_<br>CFG5 | 24   | 24  | DI<br>(pd)         | Encoder A-channel input (when using internal ramp generator)<br>or<br>DcStep gating input for axis synchronization (SD_MODE=1,<br>SPI_MODE=1) or<br>Configuration input (SPI_MODE=0)                                                                                                                                                                                   |
| ENCN_DCO_<br>CFG6  | 25   | 26  | DIO                | Encoder N-channel input (SD_MODE=0) or<br>DcStep ready output (SD_MODE=1).<br>With SD_MODE=0, pull to GND or VCC_IO, if the pin is not used<br>for an encoder.                                                                                                                                                                                                         |
| DIAG0_SWN          | 26   | 27  | DIO<br>(pu+<br>pd) | Diagnostics output DIAGO.<br>Interrupt or STEP output for motion controller (SD_MODE=0,<br>SPI_MODE=1).<br>Use external pullup resistor with 47k or less in open drain<br>mode.<br>Single wire I/O (negative) (only with SD_MODE=0 and<br>SPI_MODE=0)                                                                                                                  |
| DIAG1_SWP          | 27   | 28  | DIO<br>(pd)        | Diagnostics output DIAG1.<br>Position compare or DIR output for motion controller<br>(SD_MODE=0, SPI_MODE=1).<br>Use external pullup resistor with 47k or less in open drain<br>mode.<br>Single wire I/O (positive) (only with SD_MODE=0 and<br>SPI MODE=0)                                                                                                            |
| DRV_ENN            | 28   | 29  | DI                 | Enable input. The power stage becomes switched off (all motor outputs floating) when this pin becomes driven to a high level.                                                                                                                                                                                                                                          |
| VCC                | 29   | 30  |                    | 5V supply input for digital circuitry within chip. Provide 100nF<br>or bigger capacitor to GND (GND plane) near pin. Shall be<br>supplied by 5VOUT. A 2.2 or 3.3 Ohm resistor is recommended<br>for decoupling noise from 5VOUT. When using an external<br>supply, make sure, that VCC comes up before or in parallel to<br>5VOUT or VCC_IO, whichever comes up later! |
| СРО                | 31   | 31  |                    | Charge pump capacitor output.                                                                                                                                                                                                                                                                                                                                          |
| CPI                | 32   | 32  |                    | Charge pump capacitor input. Tie to CPO using 22nF 100V capacitor.                                                                                                                                                                                                                                                                                                     |
| VS                 | 33   | 33  |                    | Motor supply voltage. Provide filtering capacity near pin with<br>short loop to GND plane. Must be tied to the positive bridge<br>supply voltage.                                                                                                                                                                                                                      |
| VCP                | 34   | 34  |                    | Charge pump voltage. Tie to VS using 100nF capacitor.                                                                                                                                                                                                                                                                                                                  |
| CA2                | 35   | 35  |                    | Bootstrap capacitor positive connection.                                                                                                                                                                                                                                                                                                                               |
| HA2                | 36   | 36  |                    | High side gate driver output.                                                                                                                                                                                                                                                                                                                                          |

13

| Pin                | TQFP | QFN | Туре | Function                                                                                                                                                                                                                  |  |
|--------------------|------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| BMA2               | 37   | 37  |      | Bridge Center and bootstrap capacitor negative connection.                                                                                                                                                                |  |
| LA2                | 38   | 38  |      | Low side gate driver output.                                                                                                                                                                                              |  |
| LA1                | 39   | 39  |      | Low side gate driver output.                                                                                                                                                                                              |  |
| BMA1               | 40   | 40  |      | Bridge Center and bootstrap capacitor negative connection.                                                                                                                                                                |  |
| HA1                | 41   | 41  |      | High side gate driver output.                                                                                                                                                                                             |  |
| CA1                | 42   | 42  |      | Bootstrap capacitor positive connection.                                                                                                                                                                                  |  |
| CB2                | 43   | 43  |      | Bootstrap capacitor positive connection.                                                                                                                                                                                  |  |
| HB2                | 44   | 44  |      | High side gate driver output.                                                                                                                                                                                             |  |
| BMB2               | 45   | 45  |      | Bridge Center and bootstrap capacitor negative connection.                                                                                                                                                                |  |
| LB2                | 46   | 46  |      | Low side gate driver output.                                                                                                                                                                                              |  |
| LB1                | 47   | 47  |      | Low side gate driver output.                                                                                                                                                                                              |  |
| BMB1               | 48   | 1   |      | Bridge Center and bootstrap capacitor negative connection.                                                                                                                                                                |  |
| Exposed die<br>pad | -    |     |      | Connect the exposed die pad to a GND plane. Provide as many<br>as possible vias for heat transfer to GND plane. Serves as GND<br>pin for the low side gate drivers. Ensure low loop inductivity<br>to sense resistor GND. |  |

\*(pd) denominates a pin with pulldown resistor

\* All digital pins DI, DIO and DO use VCC\_IO level and contain protection diodes to GND and VCC\_IO

\* All digital inputs DI and DIO have internal Schmitt-Triggers



www.trinamic.com

### 3 Sample Circuits

The following sample circuits show the required external components in different operation and supply modes. The connection of the bus interface and further digital signals are left out for clarity.



### 3.1 Standard Application Circuit

The standard application circuit uses a minimum set of additional components. Eight MOSFETs are selected for the desired current, voltage and package type. Two sense resistors set the motor coil current. See chapter 9 to choose the right value for sense resistors. Use low ESR capacitors for filtering the power supply. A minimum capacity of 100µF per ampere of coil current near to the power bridge is recommended for best performance. The capacitors need to cope with the current ripple caused by chopper operation. Current ripple in the supply capacitors also depends on the power supply internal resistance and cable length. VCC\_IO can be supplied from 5VOUT, or from an external source, e.g. a 3.3V regulator. In order to minimize linear voltage regulator power dissipation of the internal 5V and 11.5V voltage regulators in applications where VM is high, a different (lower) supply voltage should be used for VSA (see chapter 3.2).

#### Basic layout hints

Place sense resistors and all filter capacitors as close as possible to the power MOSFETs. Place the TMC5160 near to the MOSFETs and use short interconnection lines in order to minimize parasitic trace inductance. Use a solid common GND for all GND, GNDA and GNDD connections, also for sense resistor GND. Connect 5VOUT filtering capacitor directly to 5VOUT and GNDA pin. See layout hints for more details. Low ESR electrolytic capacitors are recommended for VS filtering.

#### Hint

In safety critical applications, VS and the bridge may be supplied by a separate, switched supply in order to realize safe torque off. Make sure that the slope at VS does not exceed 1V/µs.

www.trinamic.com

Figure 3.1 Standard application circuit

#### Attention

In case VSA is supplied by a different voltage source, make sure that VSA does not drop out during motor operation. The motor driver should be disabled in case VSA becomes switched off before VS. Hard switching edges on VSA might result in bridge cross-conduction otherwise. It is safest to derive VSA voltage from VS supply.

### **3.2 External Gate Voltage Regulator**

At high supply voltages like 48V, the internal gate voltage regulator and the internal 5V regulator have considerable power dissipation, especially with high MOSFET gate charges, high chopper frequency or high system clock frequency >12MHz. A good thermal coupling of the heat slug to the system PCB GND plane is required to dissipate heat. Still, the thermal thresholds will be lowered significantly by self-heating. To reduce power dissipation, supply an external gate driver voltage to the TMC5160. Figure 3.2 shows the required connection. The internal gate voltage regulator becomes disabled in this constellation. 12V +/-1V are recommended for best results.



Figure 3.2 External gate voltage supply

Hint With MOSFETs above 50nC of total gate charge, chopper frequency >40kHz, or at clock frequency >12MHz, it is recommended to use a VSA supply not higher than 40V.



### 3.3 Choosing MOSFETs and Slope

The selection of power MOSFETs depends on a number of factors, like package size, on-resistance, voltage rating and supplier. It is not true, that larger, lower RDSon MOSFETs will always be better, as a larger device also has higher capacitances and may add more ringing in trace inductance and power dissipation in the gate drive circuitry. Adapt the MOSFETs to the required motor voltage (adding 5-10V of reserve to the peak supply voltage) and to the desired maximum current, in a way that resistive power dissipation still is low for the thermal capabilities of the chosen MOSFET package. The TMC5160 drives the MOSFET gates with roughly 10V, so normal, 10V specified types are sufficient. Logic level FETs (4.5V specified RDSon) will also work, but may be more critical with regard to bridge cross-conduction due to lower  $V_{GS(th)}$ .

The gate drive current and MOSFET gate resistors  $R_G$  (optional) determine switching behavior and should basically be adapted to the MOSFET gate-drain charge (Miller charge). Figure 3.3 shows the influence of the Miller charge on the switching event. Figure 3.4 additionally shows the switching events in different load situations (load pulling the output up or down), and the required bridge brake-before-make time.

The following table shall serve as a thumb rule for programming the MOSFET driver current (*DRVSTRENGTH* setting) and the selection of gate resistors:

| MOSFET MILLER CHARGE VS. DRVSTRENGTH AND RG |             |                             |  |  |  |
|---------------------------------------------|-------------|-----------------------------|--|--|--|
| Miller Charge                               | DRVSTRENGTH | Value of R <sub>G</sub> [Ω] |  |  |  |
| [nC] (typ.)                                 | setting     |                             |  |  |  |
| <10                                         | 0           | ≤ 15                        |  |  |  |
| 1020                                        | 0 or 1      | ≤ 10                        |  |  |  |
| 2040                                        | 1 or 2      | ≤ 7.5                       |  |  |  |
| 4060                                        | 2 or 3      | ≤ 5                         |  |  |  |
| >60                                         | 3           | ≤ 2.7                       |  |  |  |

The TMC5160 provides increased gate-off drive current to avoid bridge cross-conduction induced by high dV/dt. This protection will be less efficient with gate resistors exceeding the values given in the table. Therefore, for larger values of  $R_{G}$ , a parallel diode may be required to ensure keeping the MOSFET safely off during switching events.



#### Figure 3.3 Miller charge determines switching slope

Hints

Choose modern MOSFETs with fast and soft recovery bulk diode and low reverse recovery charge. A small, SMD MOSFET package allows compacter routing and reduces parasitic inductance effects.

- A small, SMD MOSFEL package allows compacter routing and reduces parasitic inductance

www.trinamic.com



Figure 3.4 Slopes, Miller plateau and blank time

| The following DR | /_CONF parameters | allow adapting the | e driver to the | MOSFET bridge: |
|------------------|-------------------|--------------------|-----------------|----------------|
|------------------|-------------------|--------------------|-----------------|----------------|

| Parameter   | Description                                             | Setting | Comment                                    |
|-------------|---------------------------------------------------------|---------|--------------------------------------------|
| BBMTIME     | Break-before-make time setting to ensure non-           | 024     | time[ns]≈                                  |
|             | overlapping switching of high-side and low-side         |         | 100ns*32/(32- <i>BBM<mark>TIME</mark>)</i> |
|             | MOSFETs. BBMTIME allows fine tuning of times in         |         |                                            |
|             | increments shorter than a clock period.                 |         | Ensure ~30% headroom                       |
|             | For higher times, use BBMCLKS.                          |         | Reset Default: 0                           |
| BBMCLKS     | Like <b>BBMTIME</b> , but in multiple of a clock cycle. | 015     | 0: off                                     |
|             | The longer setting rules (BBMTIME vs. BBMCLKS).         |         | Reset Default: OTP 4 or 2                  |
| DRV_        | Selection of gate driver current. Adapts the gate       | 03      | Reset Default = 2                          |
| STRENGTH    | driver current to the gate charge of the external       |         |                                            |
|             | MOSFETs.                                                |         |                                            |
| FILT_ISENSE | Filter time constant of sense amplifier to suppress     | 03      | 00: –100ns (reset default)                 |
|             | ringing and coupling from second coil operation         |         | 01: -200ns                                 |
|             | <i>Hint:</i> Increase setting if motor chopper noise    |         | 10: -300ns                                 |
|             | occurs due to cross-coupling of both coils.             |         | 11: -400ns                                 |
|             | (Reset Default = %00)                                   | OT.     |                                            |

#### DRV\_CONF Parameters

Use the lowest gate driver strength setting *DRVSTRENGTH* giving favorable switching slopes, before increasing the value of the gate series resistors. A slope time of nominal 40ns to 80ns is absolutely sufficient and will normally be covered by the shortest possible Break-Before-Make time setting (*BBMTIME*=0, *BBMCLKS*=0).

In case slower slopes have to be used, e.g. with large MOSFETs, ensure that the break-before-make time (*BBMTIME*, optionally use *BBMCLKS* for times >200ns) sufficiently covers the switching event, in order to avoid bridge cross conduction. The shortest break-before-make time, safely covering the switching event, gives best results. Add roughly 30% of reserve, to cover production stray of MOSFETs and driver.

www.trinamic.com

### 3.4 Tuning the MOSFET Bridge

A clean switching event is favorable to ensure low power dissipation and good EMC behavior. Unsuitable layout or components endanger stable operation of the circuit. Therefore, it is important to understand the effect of parasitic trace inductivity and MOSFET reverse recovery.

Stray inductance in power routing will cause ringing whenever the opposite MOSFET is in diode conduction prior to switching on a low-side or high-side MOSFET. Diode conduction occurs during break-before make time whenever the load current is inverse to the following bridge polarity. The MOSFET bulk diode has a certain, type specific reverse recovery time and charge. This time typically is in the range of a few 10ns. During reverse recovery time, the bulk diode will cause high current flow across the bridge. This current is taken from the power supply filter capacitors (see thick lines Figure 3.5). Once the diode opens parasitic inductance tries to keep the current flowing. A high, fast slope results and leads to ringing in all parasitic inductivities (see Figure 3.6). This may lead to bridge voltage undershooting the GND level as well as fast pulses on VS and all MOSFET connections. It must be ensured, that the driver IC does not see spikes on its BM pins to GND going below -5V. Severe VS ripple might overload the charge-pump circuitry. Measure the voltage directly at the driver pins to driver GND. The amount of undershooting depends on energy stored in parasitic inductivities from low side drain to low side source and via the sense resistor RS to GND.

When using relatively small MOSFETs, a soft slope control requires a high gate series resistance. This endangers safe MOSFET switch off. Add additional diodes to ensure safe MOSFET off conditions with slow switch-on slopes (shown for right MOSFET pair in Figure 3.5).

Figure 3.7 shows performance of the basic circuit after adapting switching slope and adding 1nF bridge output capacitors.



Decide use and value of the additional components based on measurements of the actual circuit using the final layout!

Figure 3.5 Bridge protection options for power routing inductivity

www.trinamic.com

#### **ENSURE RELIABLE OPERATION**

- Use SMD MOSFETs and short interconnections
- Provide sufficient power filtering capacity close to the bridge and close to VS pin
- Tune MOSFET switching slopes (measure switch-on event at MOSFET gate) to be slower than the MOSFET bulk diode reverse recovery time. This will reduce cross conduction.
- Add optional gate resistors close to MOSFET gate and output capacitors to ensure clean switching and reliable operation by minimizing ringing. Figure 3.5 shows the options plus some variations.
- Some MOSFETs eliminate reverse recovery charge by integrating a fast diode from source to drain.



Figure 3.6 Ringing of output (blue) and Gate voltages (Yellow, Cyan) with untuned brige



Figure 3.7 Switching event with optimized components (without / after bulk diode conduction)

www.trinamic.com

#### BRIDGE OPTIMIZATION EXAMPLE

A stepper driver for 6A of motor current has been designed using the MOSFET AOD4126 in the standard schematic.

The MOSFETs have a low gate capacitance and offer roughly 50ns slope time at the lowest driver strength setting. At lowest driver strength setting, switching quality is best (Figure 3.6), but still shows a lot of ringing. Low side gate resistors have been added to slightly increase switching slope time following high-side bulk diode conduction by increasing the effect of Gate-Drain (Miller) charge. High side gate resistors have been added for symmetry. Tests showed, that 1nF output capacitors dramatically reduce ringing of the power bridge following bulk diode conduction (Figure 3.7). Figure 3.8 shows the actual components and values after optimization.



#### Figure 3.8 Example for bridge with tuned components (see scope shots)

#### BRIDGE LAYOUT CONSIDERATIONS

- Tune the bridge layout for minimum loop inductivity. A compact layout is best.
- Keep MOSFET gate connections short and straight and avoid loop inductivity between BM and corresponding HS driver pin. Loop inductance is minimized with parallel traces, or adjacent traces on adjacent layers. A wider trace reduces inductivity (don't use minimum trace width).
- Minimize the length of the sense resistor connection to low-side MOSFET source, and place the TMC5160 near the sense resistor's GND connection, with its GND connections directly connected to the same GND plane.
- Optimize switching behavior by tuning gate current setting and gate resistors. Add MOSFET bridge output capacitors (470pF to a few nF) to reduce ringing.
- Measure the performance of the bridge by probing BM pins directly at the bridge or at the TMC5160 using a short GND tip on the scope probe rather than a GND cable, if available.

### 3.5 Higher Voltage Applications

Some applications require higher voltage tolerance, than the TMC5160 can directly support. For peak voltages above 60V, use an external gate driver IC boosting the TMC5160 gate driver outputs. Figure 3.9 shows a sample circuit. It uses one external gate-driver IC for each half-bridge, to boost the TMC5160 outputs. BBM control still is done by TMC5160. These ICs are 12V tolerant, so the TMC5160 output signals can be directly used for driving their control inputs. The BM pins however need to be kept near GND, in order to yield a GND-related high side control signal. By attaching BM to the respective sense resistor, the short to VS protection still can react to overcurrent conditions. Limit short detection voltage drop to 0.5V...0.8V to avoid high side outputs to reach a too high level. High-side short protection has to be disabled using *CHOPCONF.diss2g*, as it cannot work in this circuit configuration.

Keep layout and all interconnections compact, in order to avoid disturbance by parasitic effects. Also consult application notes for the selected gate driver ICs.





www.trinamic.com

# 4 SPI Interface

### 4.1 SPI Datagram Structure

The TMC5160 uses 40 bit SPI<sup>TM</sup> (Serial Peripheral Interface, SPI is Trademark of Motorola) datagrams for communication with a microcontroller. Microcontrollers which are equipped with hardware SPI are typically able to communicate using integer multiples of 8 bit. The NCS line of the device must be handled in a way, that it stays active (low) for the complete duration of the datagram transmission.

Each datagram sent to the device is composed of an address byte followed by four data bytes. This allows direct 32 bit data word communication with the register set. Each register is accessed via 32 data bits even if it uses less than 32 data bits.

For simplification, each register is specified by a one-byte address:

- For a read access the most significant bit of the address byte is 0.
- For a write access the most significant bit of the address byte is 1.

Most registers are write-only registers, some can be read additionally, and there are also some read only registers.

|                                      | SPI DATAGRAM STRUCTURE                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                         |                   |  |  |  |
|--------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------------|--|--|--|
| MSB (transmitted first)              | t) 40 bit LSB (transmitted last)                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                         |                   |  |  |  |
| 39                                   |                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                         | 0                 |  |  |  |
| → 8 bit address                      |                                                                                         | 22 hit data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                         |                   |  |  |  |
| ← 8 bit SPI status                   |                                                                                         | ← → 32 bit data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                         |                   |  |  |  |
| 39 32                                |                                                                                         | 31 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                         |                   |  |  |  |
| $\rightarrow$ to TMC5160             |                                                                                         | and the second sec |                                         |                   |  |  |  |
| RW + 7 bit address                   | 8 bit data                                                                              | 8 bit data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 8 bit data                              | 8 bit data        |  |  |  |
| ← from TMC5160                       | o Dit udla                                                                              | o DIL Udla                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | o Dit üdid                              | 8 DIT data        |  |  |  |
| 8 bit SPI status                     |                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                         |                   |  |  |  |
| 39 / 38 32                           | 31 24                                                                                   | 23 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 15 8                                    | 7 0               |  |  |  |
| w 3832                               | 3128 2724                                                                               | 2320 1916                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1512 118                                | 74 30             |  |  |  |
| 3 3 3 3 3 3 3 3 3<br>9 8 7 6 5 4 3 2 | 3     3     2     2     2     2     2     2       1     0     9     8     7     6     5 | 2 2 2 2 2 1 1 1 1<br>3 2 1 0 9 8 7 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1 1 1 1 1 1 <sub>9</sub><br>5 4 3 2 1 0 | 8 7 6 5 4 3 2 1 0 |  |  |  |

### 4.1.1 Selection of Write / Read (WRITE\_notREAD)

The read and write selection is controlled by the MSB of the address byte (bit 39 of the SPI datagram). This bit is 0 for read access and 1 for write access. So, the bit named W is a WRITE\_notREAD control bit. The active high write bit is the MSB of the address byte. So, 0x80 has to be added to the address for a write access. The SPI interface always delivers data back to the master, independent of the W bit. The data transferred back is the data read from the address which was transmitted with the *previous* datagram, if the previous access was a read access. If the previous access was a write access, then the data read back mirrors the previously received write data. So, the difference between a read and a write access is that the read access does not transfer data to the addressed register but it transfers the address only and its 32 data bits are dummies, and, further the following read or write access delivers back the data read from the address transmitted in the preceding read cycle.

A read access request datagram uses dummy write data. Read data is transferred back to the master with the subsequent read or write access. Hence, reading multiple registers can be done in a pipelined fashion.

Whenever data is read from or written to the TMC5160, the MSBs delivered back contain the SPI status, *SPI\_STATUS*, a number of eight selected status bits.

www.trinamic.com

Example:

For a read access to the register (*XACTUAL*) with the address 0x21, the address byte has to be set to 0x21 in the access preceding the read access. For a write access to the register (*VACTUAL*), the address byte has to be set to 0x80 + 0x22 = 0xA2. For read access, the data bit might have any value (-). So, one can set them to 0.

| action                  | data sent to TMC5160       | data received from TMC5160      |
|-------------------------|----------------------------|---------------------------------|
| read XACTUAL            | → 0x210000000              | $\leftarrow$ 0xSS & unused data |
| read XACTUAL            | → 0x2100000000             | $\leftarrow$ 0xss & Xactual     |
| write VMAX:= 0x00ABCDEF | $\rightarrow$ 0xa700abcdef | ← 0xSS & XACTUAL                |
| write VMAX:= 0x00123456 | → 0xA700123456             | ← 0xss00abcdef                  |

\*) S: is a placeholder for the status bits SPI\_STATUS

#### 4.1.2 SPI Status Bits Transferred with Each Datagram Read Back

New status information becomes latched at the end of each access and is available with the next SPI transfer.

| SPI_ | SPI_STATUS - status flags transmitted with each SPI access in bits 39 to 32 |                                                                            |  |  |  |  |  |
|------|-----------------------------------------------------------------------------|----------------------------------------------------------------------------|--|--|--|--|--|
| Bit  | Name                                                                        | Comment                                                                    |  |  |  |  |  |
| 7    | status_stop_r                                                               | RAMP_STAT[1] - 1: Signals stop right switch status (motion controller      |  |  |  |  |  |
|      |                                                                             | only)                                                                      |  |  |  |  |  |
| 6    | status_stop_l                                                               | RAMP_STAT[0] - 1: Signals stop left switch status (motion controller only) |  |  |  |  |  |
| 5    | position_reached                                                            | RAMP_STAT[9] - 1: Signals target position reached (motion controller only) |  |  |  |  |  |
| 4    | velocity_reached                                                            | RAMP_STAT[8] – 1: Signals target velocity reached (motion controller only) |  |  |  |  |  |
| 3    | standstill                                                                  | DRV_STATUS[31] – 1: Signals motor stand still                              |  |  |  |  |  |
| 2    | sg2                                                                         | DRV_STATUS[24] – 1: Signals StallGuard flag active                         |  |  |  |  |  |
| 1    | driver_error                                                                | GSTAT[1] – 1: Signals driver 1 driver error (clear by reading GSTAT)       |  |  |  |  |  |
| 0    | reset_flag                                                                  | GSTAT[0] - 1: Signals, that a reset has occurred (clear by reading GSTAT)  |  |  |  |  |  |

#### 4.1.3 Data Alignment

All data are right aligned. Some registers represent unsigned (positive) values, some represent integer values (signed) as two's complement numbers, single bits or groups of bits are represented as single bits respectively as integer groups.

### 4.2 SPI Signals

The SPI bus on the TMC5160 has four signals:

- SCK bus clock input
- SDI serial data input
- SDO serial data output
- CSN chip select input (active low)

published by WWW.SKYTECH.IR

The slave is enabled for an SPI transaction by a low on the chip select input CSN. Bit transfer is synchronous to the bus clock SCK, with the slave latching the data from SDI on the rising edge of SCK and driving data to SDO following the falling edge. The most significant bit is sent first. A minimum of 40 SCK clock cycles is required for a bus transaction with the TMC5160.

If more than 40 clocks are driven, the additional bits shifted into SDI are shifted out on SDO after a 40-clock delay through an internal shift register. This can be used for daisy chaining multiple chips.

CSN must be low during the whole bus transaction. When CSN goes high, the contents of the internal shift register are latched into the internal control register and recognized as a command from the master to the slave. If more than 40 bits are sent, only the last 40 bits received before the rising edge of CSN are recognized as the command.

www.trinamic.com

### 4.3 Timing

The SPI interface is synchronized to the internal system clock, which limits the SPI bus clock SCK to half of the system clock frequency. If the system clock is based on the on-chip oscillator, an additional 10% safety margin must be used to ensure reliable data transmission. All SPI inputs as well as the ENN input are internally filtered to avoid triggering on pulses shorter than 20ns. Figure 4.1 shows the timing parameters of an SPI bus transaction, and the table below specifies their values.



#### Figure 4.1 SPI timing

Hint Usually this SPI timing is referred to as SPI MODE 3

| SPI interface timing                                | AC-Charac         | teristics                                                                                             |                     |                        |                      |      |
|-----------------------------------------------------|-------------------|-------------------------------------------------------------------------------------------------------|---------------------|------------------------|----------------------|------|
|                                                     | clock perio       | od: t <sub>CLK</sub>                                                                                  |                     |                        |                      |      |
| Parameter                                           | Symbol            | Conditions                                                                                            | Min                 | Тур                    | Max                  | Unit |
| SCK valid before or after change of CSN             | tcc               |                                                                                                       | 10                  |                        |                      | ns   |
| CSN high time                                       | t <sub>сsн</sub>  | *) Min time is for<br>synchronous CLK<br>with SCK high one<br>t <sub>CH</sub> before CSN high<br>only | t <sub>cLK</sub> *) | >2t <sub>CLK</sub> +10 |                      | ns   |
| SCK low time                                        | tcl               | *) Min time is for<br>synchronous CLK<br>only                                                         | t <sub>ськ</sub> *) | >t <sub>CLK</sub> +10  |                      | ns   |
| SCK high time                                       | t <sub>CH</sub>   | *) Min time is for<br>synchronous CLK<br>only                                                         | t <sub>clk</sub> *) | >t <sub>CLK</sub> +10  |                      | ns   |
| SCK frequency using internal clock                  | fscк              | assumes minimum<br>OSC frequency                                                                      | 0 T                 |                        | 4                    | MHz  |
| SCK frequency using external<br>16MHz clock         | f <sub>scк</sub>  | assumes<br>synchronous CLK                                                                            | CI                  | κU                     | 8                    | MHz  |
| SDI setup time before rising edge of SCK            | t <sub>DU</sub>   |                                                                                                       | 10                  |                        |                      | ns   |
| SDI hold time after rising edge of SCK              | t <sub>DH</sub>   |                                                                                                       | 10                  |                        |                      | ns   |
| Data out valid time after falling<br>SCK clock edge | t <sub>DO</sub>   | no capacitive load<br>on SDO                                                                          |                     |                        | t <sub>FILT</sub> +5 | ns   |
| SDI, SCK and CSN filter delay time                  | t <sub>FILT</sub> | rising and falling edge                                                                               | 12                  | 20                     | 30                   | ns   |

www.trinamic.com

### 5 UART Single Wire Interface

The UART single wire interface allows the control of the TMC5160 with any microcontroller UART. It shares transmit and receive line like an RS485 based interface. Data transmission is secured using a cyclic redundancy check, so that increased interface distances (e.g. over cables between two PCBs) can be bridged without the danger of wrong or missed commands even in the event of electro-magnetic disturbance. The automatic baud rate detection and an advanced addressing scheme make this interface easy and flexible to use.

### 5.1 Datagram Structure

### 5.1.1 Write Access

|    | UART WRITE ACCESS DATAGRAM STRUCTURE                |    |         |                          |   |   |           |         |                       |    |       |                                             |     |                  |     |    |      |    |
|----|-----------------------------------------------------|----|---------|--------------------------|---|---|-----------|---------|-----------------------|----|-------|---------------------------------------------|-----|------------------|-----|----|------|----|
|    | each byte is LSBMSB, highest byte transmitted first |    |         |                          |   |   |           |         |                       |    |       |                                             |     |                  |     |    |      |    |
|    |                                                     |    |         |                          |   |   |           | 0       | 63                    |    |       |                                             |     |                  |     |    |      |    |
|    |                                                     | EV | nc + r  | eserved                  |   | - | 8         | bit sla | ve                    |    | V + 7 |                                             | 7   | 2 bit da         | +-  |    | CRC  |    |
| i. |                                                     | зу | IIC + I | eserveu                  |   | £ | address   |         | register addr.        |    |       |                                             | CIC |                  |     |    |      |    |
|    |                                                     |    | 0.      | 7                        |   |   |           | 815     |                       |    | 1623  |                                             |     | 2455             |     |    | 5663 |    |
| 1  | 0                                                   | 1  | 0       | Reserved (<br>but includ |   |   | SLAVEADDR |         | register<br>address 1 |    | 1     | data bytes 3, 2, 1, 0<br>(high to low byte) |     | 2, 1, 0<br>byte) | CRC |    |      |    |
| 0  | Ч                                                   | N  | æ       | 4<br>5                   | 9 | 7 | 8         | :       | 15                    | 16 | :     | 23                                          | 54  |                  | 55  | 56 | I    | 63 |

A sync nibble precedes each transmission to and from the TMC5160 and is embedded into the first transmitted byte, followed by an addressing byte. Each transmission allows a synchronization of the internal baud rate divider to the master clock. The actual baud rate is adapted and variations of the internal clock frequency are compensated. Thus, the baud rate can be freely chosen within the valid range. Each transmitted byte starts with a start bit (logic 0, low level on SWP) and ends with a stop bit (logic 1, high level on SWP). The bit time is calculated by measuring the time from the beginning of start bit (1 to 0 transition) to the end of the sync frame (1 to 0 transition from bit 2 to bit 3). All data is transmitted byte wise. The 32 bit data words are transmitted with the highest byte first.

A minimum baud rate of 9000 baud is permissible, assuming 20 MHz clock (worst case for low baud rate). Maximum baud rate is  $f_{CLK}/16$  due to the required stability of the baud clock.

The slave address is determined by the register *SLAVEADDR*. If the external address pin NEXTADDR is set, the slave address becomes incremented by one.

The communication becomes reset if a pause time of longer than 63 bit times between the start bits of two successive bytes occurs. This timing is based on the last correctly received datagram. In this case, the transmission needs to be restarted after a failure recovery time of minimum 12 bit times of bus idle time. This scheme allows the master to reset communication in case of transmission errors. Any pulse on an idle data line below 16 clock cycles will be treated as a glitch and leads to a timeout of 12 bit times, for which the data line must be idle. Other errors like wrong CRC are also treated the same way. This allows a safe re-synchronization of the transmission after any error conditions. Remark, that due to this mechanism an abrupt reduction of the baud rate to less than 15 percent of the previous value is not possible.

Each accepted write datagram becomes acknowledged by the receiver by incrementing an internal cyclic datagram counter (8 bit). Reading out the datagram counter allows the master to check the success of an initialization sequence or single write accesses. Read accesses do not modify the counter.

www.trinamic.com

### 5.1.2 Read Access

|                 | UART READ ACCESS REQUEST DATAGRAM STRUCTURE         |   |    |    |   |                     |   |           |                                |                            |      |                  |    |      |     |    |
|-----------------|-----------------------------------------------------|---|----|----|---|---------------------|---|-----------|--------------------------------|----------------------------|------|------------------|----|------|-----|----|
|                 | each byte is LSBMSB, highest byte transmitted first |   |    |    |   |                     |   |           |                                |                            |      |                  |    |      |     |    |
| sync + reserved |                                                     |   |    |    |   | 8 bit slave address |   |           | RW + 7 bit register<br>address |                            |      | CRC              |    |      |     |    |
|                 |                                                     |   | 0. | .7 |   |                     |   | 815       |                                |                            | 1623 |                  |    | 2431 |     |    |
| 1               | 0                                                   | 1 | 0  |    |   | don't c<br>ed in (  |   | SLAVEADDR |                                | SLAVEADDR register address |      | register address | 0  |      | CRC |    |
| 0               | 1                                                   | 2 | c  | 4  | 5 | 6                   | 7 | 8         | I                              | 15                         | 16   | i                | 23 | 54   | :   | 31 |

The read access request datagram structure is identical to the write access datagram structure, but uses a lower number of user bits. Its function is the addressing of the slave and the transmission of the desired register address for the read access. The TMC5160 responds with the same baud rate as the master uses for the read request.

In order to ensure a clean bus transition from the master to the slave, the TMC5160 does not immediately send the reply to a read access, but it uses a programmable delay time after which the first reply byte becomes sent following a read request. This delay time can be set in multiples of eight bit times using *SENDDELAY* time setting (default=8 bit times) according to the needs of the master. In a multi-slave system, set *SENDDELAY* to min. 2 for all slaves. Otherwise a non-addressed slaves might detect a transmission error upon read access to a different slave.

|                 |      |                                                     | UART READ ACCESS REPLY DATAGRAM STRUCTURE |                        |           |             |                     |     |                                 |                  |      |     |    |
|-----------------|------|-----------------------------------------------------|-------------------------------------------|------------------------|-----------|-------------|---------------------|-----|---------------------------------|------------------|------|-----|----|
|                 |      | each byte is LSBMSB, highest byte transmitted first |                                           |                        |           |             |                     | 1   |                                 |                  |      |     |    |
|                 | 0 63 |                                                     |                                           |                        |           |             |                     |     |                                 |                  |      |     |    |
| sync + reserved |      |                                                     |                                           | 8 bit slave<br>address |           |             | 32 bit da           | CRC |                                 |                  |      |     |    |
|                 |      |                                                     | 0.                                        | 7                      |           | 815         | 1623                |     | 2455                            |                  | 5663 |     |    |
| 1               | 0    | 1                                                   | 0                                         | res                    | erved (0) | 0xFF        | register<br>address | 0   | data bytes 3, 2<br>(high to low | 2, 1, 0<br>byte) |      | CRC |    |
| 0               | 1    | 2                                                   | e                                         | 4                      | 9         | 8<br><br>15 | 16<br>              | 53  | 24                              | 55               | 56   | :   | 63 |

The read response is sent to the master using address code %1111. The transmitter becomes switched inactive four bit times after the last bit is sent.

| Address %11111111<br>address. | is reserved | for read | accesses | going | to t | the master. | A sl | ave cannot | use this |
|-------------------------------|-------------|----------|----------|-------|------|-------------|------|------------|----------|
|                               |             |          | E        | εŪ    | E    | СТ          | R(   |            | C        |

www.trinamic.com

# published by WWW.SKYTECH.IR

### 5.2 CRC Calculation

An 8 bit CRC polynomial is used for checking both read and write access. It allows detection of up to eight single bit errors. The CRC8-ATM polynomial with an initial value of zero is applied LSB to MSB, including the sync- and addressing byte. The sync nibble is assumed to always be correct. The TMC5160 responds only to correctly transmitted datagrams containing its own slave address. It increases its datagram counter for each correctly received write access datagram.

$$CRC = x^8 + x^2 + x^1 + x^0$$

#### SERIAL CALCULATION EXAMPLE

CRC = (CRC << 1) OR (CRC.7 XOR CRC.1 XOR CRC.0 XOR [new incoming bit])



### 5.3 UART Signals

The UART interface on the TMC5160 comprises four signals:

| TMC5160 UART | TMC5160 UART INTERFACE SIGNALS                                                        |  |  |  |  |  |  |
|--------------|---------------------------------------------------------------------------------------|--|--|--|--|--|--|
| SWP          | Ion-inverted data input and output                                                    |  |  |  |  |  |  |
| SWN          | Inverted data input and output for use in differential transmission. Can be left open |  |  |  |  |  |  |
|              | in a 5V IO voltage system. Tie to the half IO level voltage for best performance in a |  |  |  |  |  |  |
|              | 3.3V single wire non-differential application.                                        |  |  |  |  |  |  |
| SDI_CFG1     | Address increment pin for chained sequential addressing scheme                        |  |  |  |  |  |  |
| (NAI)        |                                                                                       |  |  |  |  |  |  |
| SDO_CFG0     | Next address output pin for chained sequential addressing scheme (reset default=      |  |  |  |  |  |  |
| (NAO)        | high) ELEGIKONIG                                                                      |  |  |  |  |  |  |

In UART mode (SPI\_MODE low and SD\_MODE low) the slave checks the single wire SWP and SWN for correctly received datagrams with its own address continuously. Both signals are switched as input during this time. It adapts to the baud rate based on the sync nibble, as described before. In case of a read access, it switches on its output drivers on SWP and SWN and sends its response using the same baud rate.

www.trinamic.com

### 5.4 Addressing Multiple Slaves

#### ADDRESSING ONE OR TWO SLAVES

If only one or two TMC5160 are addressed by a master using a single UART interface, a hardware address selection can be done by setting the NAI pins of both devices to different levels.

#### ADDRESSING UP TO 255 SLAVES

A different approach can address any number of devices by using the input NAI as a selection pin. Addressing up to 255 units is possible.



#### Figure 5.1 Addressing multiple TMC5160 via single wire interface using chaining

PROCEED AS FOLLOWS:

- Tie the NAI pin of your first TMC5160 to GND.
- Interconnect NAO output of the first TMC5160 to the next drivers NAI pin. Connect further drivers in the same fashion.
- Now, the first driver responds to address 0. Following drivers are set to address 1.
- Program the first driver to its dedicated slave address. Note: once a driver is initialized with its slave address, its NAO output, which is tied to the next drivers NAI has to be programmed to logic 0 in order to differentiate the next driver from all following devices.
- Now, the second driver is accessible and can get its slave address. Further units can be programmed to their slave addresses sequentially.

29

www.trinamic.com



#### Figure 5.2 Addressing multiple TMC5160 via the differential interface, additional filtering for NAI

A different scheme (not shown) uses bus switches (like 74HC4066) to connect the bus to the next unit in the chain without using the NAI input. The bus switch can be controlled in the same fashion, using the NAO output to enable it (low level shall enable the bus switch). Once the bus switch is enabled it allows addressing the next bus segment. As bus switches add a certain resistance, the maximum number of nodes will be reduced.

It is possible to mix different styles of addressing in a system. For example, a system using two boards with each two TMC5160 can have both devices on a board with a different level on NEXTADDR, while the next board is chained using analog switches separating the bus until the drivers on the first board have been programmed.



www.trinamic.com

## 6 Register Mapping

This chapter gives an overview of the complete register set. Some of the registers bundling a number of single bits are detailed in extra tables. The functional practical application of the settings is detailed in dedicated chapters.

#### Note

- All registers become reset to 0 upon power up, unless otherwise noted. - Add 0x80 to the address **Addr** for write accesses!

| NOTATION OF HEXADECIMAL AND BINARY NUMBERS |                                               |
|--------------------------------------------|-----------------------------------------------|
| 0x                                         | precedes a hexadecimal number, e.g. 0x04      |
| %                                          | precedes a multi-bit binary number, e.g. %100 |
|                                            |                                               |

| Νοτ | ATION O | OF R/W FIELD |                             |
|-----|---------|--------------|-----------------------------|
| R   |         |              | Read only                   |
| W   |         |              | Write only                  |
| R/W |         |              | Read- and writable register |
| R+C |         |              | Clear upon read             |

#### OVERVIEW REGISTER MAPPING

| REGISTER                                                  | DESCRIPTION                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| General Configuration Registers                           | These registers contain<br>- global configuration                                                                                                                                                                                                                                                            |
|                                                           | <ul> <li>global status flags</li> <li>interface configuration</li> <li>and I/O signal configuration</li> </ul>                                                                                                                                                                                               |
| Ramp Generator Motion Control Register Set                | This register set offers registers for<br>- choosing a ramp mode<br>- choosing velocities<br>- homing                                                                                                                                                                                                        |
|                                                           | <ul> <li>acceleration and deceleration</li> <li>target positioning</li> <li>reference switch and StallGuard2 event<br/>configuration</li> <li>ramp and reference switch status</li> </ul>                                                                                                                    |
| Velocity Dependent Driver Feature Control Register<br>Set | This register set offers registers for<br>- driver current control<br>- setting thresholds for CoolStep operation<br>- setting thresholds for different chopper modes<br>- setting thresholds for DcStep operation                                                                                           |
| Encoder Register Set                                      | The encoder register set offers all registers needed for proper ABN encoder operation.                                                                                                                                                                                                                       |
| Motor Driver Register Set                                 | <ul> <li>This register set offers registers for</li> <li>setting / reading out microstep table and counter</li> <li>chopper and driver configuration</li> <li>CoolStep and StallGuard2 configuration</li> <li>DcStep configuration</li> <li>reading out StallGuard2 values and driver error flags</li> </ul> |

www.trinamic.com

### 6.1 General Configuration Registers

| GENER/ | AL CONFI | GURATI | ON REGISTERS ( | 0x000  | x0F)                                                        |
|--------|----------|--------|----------------|--------|-------------------------------------------------------------|
| R/W    | Addr     | n      | Register       | Descri | otion / bit names                                           |
|        |          |        | _              | Bit    | GCONF – Global configuration flags                          |
|        |          |        |                | 0      | recalibrate                                                 |
|        |          |        |                |        | 1: Zero crossing recalibration during driver disable        |
|        |          |        |                |        | (via ENN or via TOFF setting)                               |
|        |          |        |                | 1      | faststandstill                                              |
|        |          |        |                |        | Timeout for step execution until standstill detection:      |
|        |          |        |                |        | 1: Short time: 2 <sup>18</sup> clocks                       |
|        |          |        |                |        | 0: Normal time: 2 <sup>2</sup> 0 clocks                     |
|        |          |        |                | 2      | en_pwm_mode                                                 |
|        |          |        |                |        | 1: StealthChop voltage PWM mode enabled                     |
|        |          |        |                |        | (depending on velocity thresholds). Switch from             |
|        |          |        |                |        | off to on state while in stand-still and at IHOLD=          |
|        |          |        |                |        | nominal IRUN current, only.                                 |
|        |          |        |                | 3      | multistep_filt                                              |
|        |          |        |                |        | 1: Enable step input filtering for StealthChop              |
|        |          |        |                |        | optimization with external step source (default=1)          |
|        |          |        |                | 4      | shaft                                                       |
|        |          |        |                |        | 1: Inverse motor direction                                  |
|        |          |        |                | 5      | diag0_error (only with SD_MODE=1)                           |
|        |          |        |                |        | 1: Enable DIAGO active on driver errors:                    |
|        |          |        |                |        | Over temperature (ot), short to GND (s2g),                  |
|        |          |        |                |        | undervoltage chargepump (uv_cp)                             |
|        |          |        |                |        | DIAGO always shows the reset-status, i.e. is active low     |
|        |          |        |                | 6      | during reset condition.<br>diag0_otpw (only with SD_MODE=1) |
| RW     | 0x00     | 17     | GCONF          | 0      | 1: Enable DIAGO active on driver over temperature           |
|        | 0,00     | 11     | deoin          |        | prewarning (otpw)                                           |
|        |          |        |                | 7      | diag0_stall (with SD_MODE=1)                                |
|        |          |        |                |        | 1: Enable DIAGO active on motor stall (set                  |
|        |          |        |                |        | TCOOLTHRS before using this feature)                        |
|        |          |        |                |        | diag0_step (with SD_MODE=0)                                 |
|        |          |        |                |        | 0: DIAGO outputs interrupt signal                           |
|        |          |        |                |        | 1: Enable DIAGO as STEP output (half frequency,             |
|        |          |        |                |        | dual edge triggered) for external STEP/DIR driver           |
|        |          |        |                | 8      | diag1_stall (with SD_MODE=1)                                |
|        |          |        |                |        | 1: Enable DIAG1 active on motor stall (set                  |
|        |          |        |                |        | TCOOLTHRS before using this feature)                        |
|        |          |        |                |        | diag1_dir (with SD_MODE=0)                                  |
|        |          |        |                |        | 0: DIAG1 outputs position compare signal                    |
|        |          |        |                |        | 1: Enable DIAG1 as DIR output for external STEP/DIR         |
|        |          |        |                |        | driver                                                      |
|        |          |        |                | 9      | <pre>diag1_index (only with SD_MODE=1)</pre>                |
|        |          |        |                |        | 1: Enable DIAG1 active on index position (microstep         |
|        |          |        |                |        | look up table position 0)                                   |
|        |          |        |                | 10     | diag1_onstate (only with SD_MODE=1)                         |
|        |          |        |                |        | 1: Enable DIAG1 active when chopper is on (for the          |
|        |          |        |                |        | coil which is in the second half of the fullstep)           |
|        |          |        |                | 11     | diag1_steps_skipped (only with SD_MODE=1)                   |
|        |          |        |                |        | 1: Enable output toggle when steps are skipped in           |
|        |          |        |                |        | DcStep mode (increment of LOST_STEPS). Do not               |
|        |          |        |                |        | enable in conjunction with other DIAG1 options.             |

www.trinamic.com

| GENERAL CONFIGURATION REGISTERS (0x000x0F) |      |   |           |                                                                                                                                                                                                                                                                                                                |
|--------------------------------------------|------|---|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R/W                                        | Addr | n | Register  | Description / bit names                                                                                                                                                                                                                                                                                        |
|                                            |      |   |           | <ul> <li>12 diag0_int_pushpull</li> <li>0: SWN_DIAG0 is open collector output (active low)</li> <li>1: Enable SWN_DIAG0 push pull output (active high)</li> </ul>                                                                                                                                              |
|                                            |      |   |           | <ul> <li>13 diag1_poscomp_pushpull</li> <li>0: SWP_DIAG1 is open collector output (active low)</li> <li>1: Enable SWP_DIAG1 push pull output (active high)</li> </ul>                                                                                                                                          |
|                                            |      |   |           | <ul> <li>14 small_hysteresis</li> <li>0: Hysteresis for step frequency comparison is 1/16</li> <li>1: Hysteresis for step frequency comparison is 1/32</li> </ul>                                                                                                                                              |
|                                            |      |   |           | <ul> <li>15 stop_enable</li> <li>0: Normal operation</li> <li>1: Emergency stop: ENCA_DCIN_stops the sequencer</li> </ul>                                                                                                                                                                                      |
|                                            |      |   |           | when tied high (no steps become executed by the sequencer, motor goes to standstill state).                                                                                                                                                                                                                    |
|                                            |      |   |           | 16 direct_mode<br>0: Normal operation<br>1: Motor coil currents and polarity directly                                                                                                                                                                                                                          |
|                                            |      |   |           | programmed via serial interface: Register XTARGET<br>(0x2D) specifies signed coil A current (bits 80)<br>and coil B current (bits 2416). In this mode, the                                                                                                                                                     |
|                                            |      |   |           | current is scaled by <i>IHOLD</i> setting. Velocity based<br>current regulation of StealthChop is not available<br>in this mode. The automatic StealthChop current                                                                                                                                             |
|                                            |      |   |           | regulation will work only for low stepper motor<br>velocities.<br>17 test_mode                                                                                                                                                                                                                                 |
|                                            |      |   |           | 0: Normal operation<br>1: Enable analog test output on pin ENCN_DCO.<br>IHOLD[10] selects the function of ENCN DCO:                                                                                                                                                                                            |
|                                            |      |   |           | 02: T120, DAC, VDDH<br>Hint: Not for user, set to 0 for normal operation!<br>Bit GSTAT – Global status flags                                                                                                                                                                                                   |
|                                            | ,    |   |           | (Re-Write with '1' bit to clear respective flags)<br>0 reset                                                                                                                                                                                                                                                   |
|                                            |      |   |           | <ul> <li>1: Indicates that the IC has been reset. All registers have been cleared to reset values.</li> <li>1 drv_err</li> <li>1: Indicates, that the driver has been shut down</li> </ul>                                                                                                                     |
| R+<br>WC                                   | 0x01 | 3 | GSTAT     | due to overtemperature or short circuit detection.<br>Read DRV_STATUS for details. The flag can only<br>be cleared when the temperature is below the                                                                                                                                                           |
|                                            |      |   |           | limit again.<br>2 uv_cp                                                                                                                                                                                                                                                                                        |
|                                            |      |   |           | 1: Indicates an undervoltage on the charge pump.<br>The driver is disabled during undervoltage. This<br>flag is latched for information.                                                                                                                                                                       |
| R                                          | 0x02 | 8 | IFCNT     | Interface transmission counter. This register becomes<br>incremented with each successful UART interface write access.<br>It can be read out to check the serial transmission for lost<br>data. Read accesses do not change the content. Disabled in SPI<br>operation. The counter wraps around from 255 to 0. |
| W                                          | 0x03 | 8 | SLAVECONF | Bit SLAVECONF                                                                                                                                                                                                                                                                                                  |

| R       0x04       8       IOIN       8         R       0x04       8       IOIN       8         V       0x04       1       OUTPUT       Reads the state of all input pins available         V       0x04       1       OUTPUT       Reads the state of all input pins available         W       0x04       1       OUTPUT       Reads the state of all input pins available         W       0x04       1       OUTPUT       Reads the state of all input pins available         W       0x04       1       OUTPUT       Reads the state of all input pins available         W       0x04       1       OUTPUT       Reads the state of all input pins available         W       0x04       1       OUTPUT       Reads the state of all input pins available         W       0x04       1       OUTPUT       Reads the state of all input pins available         W       0x04       1       OUTPUT       Sets the IO output pin polarity in UART mode         W       0x04       1       OUTPUT       Sets the IO output pin polarity in UART mode         W       0x05       32       X_COMPARE       X_COMPARE         W       0x05       32       X_COMPARE       X_COMPARE         X_COM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | GENER | AL CONFIG | GURATI | ON REGISTERS ( | (0x000x0F)                                                                                                                                                                                                                                                                                                                                                       |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| R       0x04       8         W       0x04       1         OUTPUT       0       In Output         W       0x04       1         W       0x04       1         OUTPUT       0       In Output         Output       0       In Output         Output       0       In Output         Position       0x04       1         Output       0       In Output         Position       0x04       1         IV       0x04       1       0         IV       0x04       1       IV         IV       IV       IV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R/W   | Addr      | n      | Register       | Description I bit names                                                                                                                                                                                                                                                                                                                                          |  |  |
| R       0x04       8       IOIN       Bit       INPUT         R       0x04       8       IOIN       Reads the state of all input pins available         0       REFL_STEP       1       REFL_STEP       1       REFL_STEP         1       REFL_STEP       1       REFL_STEP       1       REFL_STEP         2       ENCA_DCIN_CFG5       3       ENCA_DCIN_CFG5       3       SWN associated of the state of all input pins available         3       IOIN       SEST MODE (1-External step and dir source)       7       SWCOMP_IN (Shows voltage difference of SWN associated of SWN associated of the SWN associated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |           |        |                | These eight bits set the address of unit for the UART<br>interface. The address becomes incremented by one<br>when the external address pin NEXTADDR is active.<br>Range: 0-253 (254 cannot be incremented), default=0118SENDDELAY:<br>0, 1: 8 bit times (not allowed with multiple slaves)<br>2, 3: 3*8 bit times<br>4, 5: 5*8 bit times<br>6, 7: 7*8 bit times |  |  |
| R       0x04       8       IOIN       Bit       INPUT         R       0x04       8       IOIN       REFL_STEP       1         R       0x04       8       IOIN       2       ENCB_DCEN_CFG4         3       ENCA_DCIN_CFG5       4       DRV_ENN         5       ENC_N_DCO_CFG6       6       5D_MODE (1=External step and dir source)         7       SWCOMP_IN_Chows voltage difference of SWN a SWP. Bring DIAG outputs to high level with pushp disabled to test the comparator.)         31       VERSION: 0x30-first version of the IC Identical numbers mean full digital compatibility.         W       0x04       1       OUTPUT         Sets the IO output pin polarity in UART mode       0       In UART mode, SD0_CFG0 is an output. This programs the output polarity of this pin. Its ma purpose it to use SD0_CFG0 as NAO next addre output signal for chain addressing of multiple ICs. Hint: Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE       XCTUAL = X_COMPARE:         W       0x05       32       X_COMPARE       OTP_PROGRAM - OTP programming<br>Write access programs OTP memory (one bit at a tim Read access regreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access regreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| R       0x04       8       IOIN       Bit       INPUT       Reads the state of all input pins available       0       REFL_STEP       1       1       REFL_STEP       1       Restarded to the transited to the transited to the transited to the trans to a lowstate is 1 for use as NAO to next IC single wi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |        |                | 12, 13: 13*8 bit times                                                                                                                                                                                                                                                                                                                                           |  |  |
| R       0x04       8         R       0x04       8         IOIN       8         IOIN       9         ENCB_DCEN_CFG4         S       ENCB_DCEN_CFG5         4       DRV ENN         5       ENC_N_DCO_CFG6         6       SD_MODE (1-External step and dir source)         7       SWCOMP_IN (Shows voltage difference of SWN a SWP, Bring DIAG outputs to high level with pushp disabled to test the comparator.)         31       VERSION: 0x30-first version of the IC Identical numbers mean full digital compatibility.         W       0x04       1         W       0x04       1         W       0x04       1         W       0x05       32         X_COMPARE       -         V       0x05         32       X_COMPARE         -       -         Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         Bit       OTP_PROGAM - OTP programming         Wirite access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs in the output for the part and the submemory (one bit at a tim Read access refreshes read data from OTP after a write access programs in the output for the part and the submemory (one bit at a tim Read access preacember of the part and the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| R       0x04       8         IOIN       8         IOIN       9         ENCA_DCIN_CFG4         3       ENCA_DCIN_CFG5         4       0x04         8       IOIN         5       ENCA_DCIN_CFG5         6       SD_MODE (1-External step and dir source)         7       SWCOMP_IN (Shows voltage difference of SWN a SWP. Bring DIAG outputs to high level with pushp disabled to test the comparator.)         W       0x04         W       0x04         1       OUTPUT         Sets the IO output pin polarity in UART mode         0       In UART mode, SDO_CFG0 is an output. This programs the output polarity of this pin. Its mapurpose it to use SDO_CFG0 as NAO next addre output signal for chain addressing of multiple ICs. Hint: Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32         X_COMPARE       -         Output signal For motion controller positis strobe. The Position pulse is available on output SWP_DIAG1         W       0x05       32         X_COMPARE       -         OUTP PROGA       0.0         OUTP PROGA       0.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |           |        | IOIN           |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| R       0x04       8       IOIN       1       REFR_DIR         2       ENCB_DCEN_CFG4       3       ENCA_DCIN_CFG5         4       DRV_ENN       5       ENC_N_DCO_CFG6         5       ENC_N_DCO_CFG6       6       SD_MODE (1-External step and dir source)         7       SWCOMP_IN (Shows voltage difference of SWN a SWP. Bring DIAG outputs to high level with pushp disabled to test the comparator.)       31       VERSION: 0x30-first version of the IC         24       Identical numbers mean full digital compatibility.       0       In UART mode, SD0_CFG0 is an output. This programs the output polarity of this pin. Its mm purpose it to use SD0_CFG0 as NAO next addressing of multiple ICs. Hint: Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE         VACTUAL = X_COMPARE       -       Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         W       0x06       0TP_PROG       20       0TPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| R       0x04       8       IOIN       2       ENCB_DCEN_CFG4         3       ENCA_DCIN_CFG5       4       DRV_ENN         5       ENC_N_DCO_CFG6       6       SD_MODE (1=External step and dir source)         7       SWCOMP_IN (Shows voltage difference of SWN a SWP. Bring DIAG outputs to high level with pushp disabled to test the comparator.)         31       VERSION: 0x30-first version of the IC         24       Identical numbers mean full digital compatibility.         Bit       OUTPUT         Sets the IO output pin polarity in UARI mode         0       In UART mode, SDO_CFG0 as no output. This programs the output polarity of this pin. Its ma purpose it to use SDO_CFG0 as NAO next addre output signal for chain addressing of multiple ICs. Hint: Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE         X_COMPARE       XACTUAL = X_COMPARE:       - Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         W       0x06       OTP_PROG       20       OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| R       0x04       8       IOIN       3       ENCA_DCIN_CFG5         4       DRV_ENN       5       ENC_N_DC0_CFG6       6       SD_MODE (1=External step and dir source)         7       SWCOMP_IN (Shows voltage difference of SWN a sWP. Bring DIAG outputs to high level with pushp disabled to test the comparator.)       31       VERSION: 0x30-first version of the IC         24       Identical numbers mean full digital compatibility.       Bit       OUTPUT         Sets the IO output pin polarity in UART mode       0       In UART mode, SD0_CFG0 is an output. This programs the output polarity of this pin. Its ma purpose it to use SD0_CFG0 as NAO next addres output signal for chain addressing of multiple ICs. Hint: Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE       Position comparison register for motion controller positis strobe. The Position pulse is available on output SWP_DIAG1         W       0x06       0IP PROG       20       0TPPROGRAM - OTP programming         W       0x06       0IP PROG       20       0TPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |           |        |                | -                                                                                                                                                                                                                                                                                                                                                                |  |  |
| R       0x04       0       IOIN       4       DRV_ENN         5       ENC_N_DCO_CFG6       6       SD_MODE (1=External step and dir source)         7       SWCOMP_IN (Shows voltage difference of SWN a SWP. Bring DIAG outputs to high level with pushp disabled to test the comparator.)         31       VERSION: 0x30-first version of the IC         24       Identical numbers mean full digital compatibility.         Bit       OUTPUT         Sets the IO output pin polarity in UART mode         0       In UART mode, SD0_CFG0 is an output. This programs the output polarity of this pin. Its mapurpose it to use SD0_CFG0 as NAO next addres output signal for chain addressing of multiple ICs. Hint: Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE         XACTUAL = X_COMPARE:       -       Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         W       0x06       0IP PROG       20       0TPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| K       0x04       *       101N       5       ENC_N_DCO_CFG6         6       SD_MODE (1=External step and dir source)       7       SWCOMP_IN (Shows voltage difference of SWN a SWP. Bring DIAG outputs to high level with pushp disabled to test the comparator.)         31       VERSION: 0x30=first version of the IC       24         Identical numbers mean full digital compatibility.       Bit       OUTPUT         Sets the IO output pin polarity in UART mode       0       In UART mode, SD0_CFG0 is an output. This programs the output polarity of this pin. Its ma purpose it to use SD0_CFG0 as NA0 next addre output signal for chain addressing of multiple ICs. Hint: Reset Value is 1 for use as NA0 to next IC single wire chain         W       0x05       32       X_COMPARE         X_COMPARE       XACTUAL = X_COMPARE:       -         Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.       Bit         W       0x06       OTP_PROG       20       OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| W       0x05       32       X_COMPARE       6       SD_MODE (1=External step and dir source)         7       SWCOMP_IN (Shows voltage difference of SWN a SWP. Bring DIAG outputs to high level with pushp disabled to test the comparator.)       31       VERSION: 0x30=first version of the IC         24       Identical numbers mean full digital compatibility.       Bit       OUTPUT         Sets the IO output pin polarity in UART mode       0       In UART mode, SD0_CFG0 is an output. This programs the output polarity of this pin. Its mapurpose it to use SD0_CFG0 as NA0 next addresoutput signal for chain addressing of multiple ICs. Hint: Reset Value is 1 for use as NA0 to next IC single wire chain         W       0x05       32       X_COMPARE         XACTUAL = X_COMPARE:       -       Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         Bit       OTP_PROGRAM - OTP programming       Write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data                                                                                                                                                                                                               | ĸ     | 0x04      |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| W       0x04       1       OUTPUT       Sets the IO output pin polarity in UART mode         W       0x04       1       OUTPUT       Sets the IO output pin polarity in UART mode         W       0x04       1       OUTPUT       Sets the IO output pin polarity in UART mode         W       0x04       1       OUTPUT       Sets the IO output pin polarity of this pin. Its mapurpose it to use SD0_CFG0 as NAO next addressing of multiple ICs. Hint: Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE         W       0x05       32       X_COMPARE         W       0x06       OTP_PROG       2.0         OTP_PROGRAM - OTP programming       Write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access                                                                                                                                                                                                                                                                                             |       |           |        |                | 6 SD_MODE (1=External step and dir source)                                                                                                                                                                                                                                                                                                                       |  |  |
| W       0x04       1       OUTPUT       Sets the IO output pin polarity in UART mode         W       0x04       1       OUTPUT       Sets the IO output pin polarity of this pin. Its mapurpose it to use SD0_CFG0 is an output. This programs the output polarity of this pin. Its mapurpose it to use SD0_CFG0 as NAO next addresoing of multiple ICs. Hint: Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE         W       0x05       32       X_COMPARE         W       0x06       OTP_PROG       2.0         W       0x06       OTP_PROG       2.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |           |        |                | SWP. Bring DIAG outputs to high level with pushpul                                                                                                                                                                                                                                                                                                               |  |  |
| W       0x04       1       OUTPUT       Bit       OUTPUT         W       0x04       1       OUTPUT       Sets the IO output pin polarity in UART mode         W       0x04       1       OUTPUT       In       UART mode, SDO_CFGO is an output. This programs the output polarity of this pin. Its mapurpose it to use SDO_CFGO as NAO next addresoutput signal for chain addressing of multiple ICs. <i>Hint:</i> Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE       Position comparison register for motion controller positistrobe. The Position pulse is available on output SWP_DIAG1         W       0x05       32       X_COMPARE       XACTUAL = X_COMPARE:<br>- Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         Bit       OTP_PROGRAM - OTP programming<br>Write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP memory (one bit at a tim Read access programs OTP m                                                                                                                                                                                                  |       |           |        |                | 31 VERSION: 0x30=first version of the IC                                                                                                                                                                                                                                                                                                                         |  |  |
| W       0x04       1       OUTPUT       Sets the IO output pin polarity in UART mode         W       0x04       1       OUTPUT       In UART mode, SDO_CFGO is an output. This programs the output polarity of this pin. Its mapurpose it to use SDO_CFGO as NAO next addresoutput signal for chain addressing of multiple ICs. <i>Hint:</i> Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE       Position comparison register for motion controller positi strobe. The Position pulse is available on output SWP_DIAG1         W       0x05       32       X_COMPARE       -       Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         W       0x06       OTP_PROG       20       OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| W       0x04       1       OUTPUT       0       In UART mode, SD0_CFG0 is an output. This programs the output polarity of this pin. Its mapurpose it to use SD0_CFG0 as NAO next addresoutput signal for chain addressing of multiple ICs. <i>Hint:</i> Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE       Position comparison register for motion controller positi strobe. The Position pulse is available on output SWP_DIAG1         W       0x05       32       X_COMPARE       Vactual = X_COMPARE:       -         W       0x06       0TP_PR0G       2.0       OTP_PROGRAM - OTP programming         W       0x06       0TP_PR0G       20       OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| W       0x04       1       OUTPUT       programs the output polarity of this pin. Its mapurpose it to use SDO_CFG0 as NAO next addresoutput signal for chain addressing of multiple ICs. Hint: Reset Value is 1 for use as NAO to next IC single wire chain         W       0x05       32       X_COMPARE       Position comparison register for motion controller positistrobe. The Position pulse is available on output SWP_DIAG1         W       0x05       32       X_COMPARE       XACTUAL = X_COMPARE:<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| W       0x05       32       X_COMPARE       Position comparison register for motion controller positi strobe. The Position pulse is available on output SWP_DIAG1         W       0x05       32       X_COMPARE       -       Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         W       0x06       OTP_PROG       20       OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | W     | 0x04 🗸    | 1      | OUTPUT         | programs the output polarity of this pin. Its main purpose it to use SDO_CFGO as NAO next address                                                                                                                                                                                                                                                                |  |  |
| W       0x05       32       X_COMPARE       Position comparison register for motion controller positing strobe. The Position pulse is available on output SWP_DIAG1         W       0x05       32       X_COMPARE       -       Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         W       0x06       OTP_PROG       20       OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| W       0x05       32       X_COMPARE       Position comparison register for motion controller positi strobe. The Position pulse is available on output SWP_DIAG1         W       0x05       32       X_COMPARE       XACTUAL = X_COMPARE:<br>- Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         W       0x06       OTP_PROG       Bit       OTP_PROGRAM - OTP programming<br>Write access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write a comparison of the position of the                      |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| W       0x05       32       X_COMPARE       strobe. The Position pulse is available on output SWP_DIAG1         XACTUAL = X_COMPARE:       Output signal PP (position pulse) becomes high. returns to a low state, if the positions mismatch.         Bit       OTP_PROGRAM - OTP programming         Wite access programs OTP memory (one bit at a tim Read access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access refreshes read data from OTP after a write access from the program for |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| W       0x06       OTP_PROG       20       OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |           |        |                | strobe. The Position pulse is available on output SWP_DIAG1.                                                                                                                                                                                                                                                                                                     |  |  |
| W       0x06       OTP_PROG       20       OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | w     | 0x05      | 32     | X_COMPARE      | _                                                                                                                                                                                                                                                                                                                                                                |  |  |
| W       0x06       OTP_PROG       Bit       OTP_PROGRAM - OTP programming         W       0x06       OTP_PROG       20       OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| Read access refreshes read data from OTP after a wri           W         0x06         OTP PROG         20         OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | W     | 0x06      |        | OTP_PROG       |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| W 0x06 OTP PROG 20 OTPBIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |           |        |                | Write access programs OTP memory (one bit at a time),                                                                                                                                                                                                                                                                                                            |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |           |        |                | Read access refreshes read data from OTP after a write                                                                                                                                                                                                                                                                                                           |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| Selection of UTP bit to be programmed to the select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |           |        |                | Selection of OTP bit to be programmed to the selected                                                                                                                                                                                                                                                                                                            |  |  |
| byte location (n=07: programs bit n to a logic 1)<br>54 OTPBYTE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| S4 OTPBYTE<br>Set to 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |           |        |                |                                                                                                                                                                                                                                                                                                                                                                  |  |  |

| GENERAL CONFIGURATION REGISTERS (0x000x0F) |      |    |                |                                |                                                                                                            |  |
|--------------------------------------------|------|----|----------------|--------------------------------|------------------------------------------------------------------------------------------------------------|--|
| R/W                                        | Addr | n  | Register       | Description <i>I bit names</i> |                                                                                                            |  |
|                                            |      |    |                | 158                            | OTPMAGIC                                                                                                   |  |
|                                            |      |    |                |                                | Set to 0xbd to enable programming. A programming                                                           |  |
|                                            |      |    |                |                                | time of minimum 10ms per bit is recommended (check                                                         |  |
|                                            |      |    |                | D'.                            | by reading OTP_READ).                                                                                      |  |
| р                                          | 0.07 |    |                | Bit                            | <b>OTP_READ</b> (Access to OTP memory result and update)                                                   |  |
| R                                          | 0x07 |    | OTP_READ       | 70                             | See separate table!<br>OTPO byte 0 read data                                                               |  |
|                                            |      |    |                | 40                             | FCLKTRIM (Reset default: OTP)                                                                              |  |
|                                            |      |    |                | 40                             | 031: Lowest to highest clock frequency. Check at                                                           |  |
|                                            |      |    |                |                                | charge pump output. The frequency span is not                                                              |  |
| RW                                         | 0x08 | 5  | FACTORY_       |                                | guaranteed, but it is tested, that tuning to 12MHz                                                         |  |
|                                            |      |    | CONF           |                                | internal clock is possible. The devices come preset to                                                     |  |
|                                            |      |    |                |                                | 12MHz clock frequency by OTP programming.                                                                  |  |
|                                            |      |    |                |                                | (Reset Default: OTP)                                                                                       |  |
|                                            |      |    |                | Bit                            | SHORT_CONF                                                                                                 |  |
|                                            |      |    |                | 30                             | S2VS_LEVEL:                                                                                                |  |
|                                            |      |    |                |                                | Short to VS detector level for lowside FETs. Checks for                                                    |  |
|                                            |      |    |                |                                | voltage drop in LS MOSFET and sense resistor.<br>4 (highest sensitivity) 15 (lowest sensitivity)           |  |
|                                            |      |    |                |                                | 4 (ingliest sensitivity) 15 (lowest sensitivity)                                                           |  |
|                                            |      |    |                |                                | Hint: Settings from 1 to 3 will trigger during normal                                                      |  |
|                                            |      |    |                |                                | operation due to voltage drop on sense resistor.                                                           |  |
|                                            |      |    |                |                                | (Reset Default: OTP 6 or 12)                                                                               |  |
|                                            |      |    |                | 118                            | S2G_LEVEL:                                                                                                 |  |
|                                            |      |    |                |                                | Short to GND detector level for highside FETs. Checks                                                      |  |
|                                            | 0x09 | 19 | SHORT_<br>CONF |                                | for voltage drop on high side MOSFET                                                                       |  |
| W                                          |      |    |                |                                | 2 (highest sensitivity) 15 (lowest sensitivity)                                                            |  |
| vv                                         |      |    |                |                                | Attention: Settings below 6 not recommended at >52V operation – false detection might result               |  |
|                                            |      |    |                |                                | (Reset Default: OTP 6 or 12)                                                                               |  |
|                                            |      |    |                | 1716                           | SHORTFILTER:                                                                                               |  |
|                                            |      |    |                |                                | Spike filtering bandwidth for short detection                                                              |  |
|                                            | 1    |    |                |                                | 0 (lowest, 100ns), 1 (1µs), 2 (2µs) 3 (3µs)                                                                |  |
|                                            |      |    |                |                                | Hint: A good PCB layout will allow using setting 0.                                                        |  |
|                                            |      |    |                |                                | Increase value, if erroneous short detection occurs.                                                       |  |
|                                            |      |    |                | 10                             | (Reset Default = %01)                                                                                      |  |
|                                            |      |    |                | 18                             | shortdelay: Short detection delay<br>0=750ns: normal, 1=1500ns: high                                       |  |
|                                            |      |    |                |                                | The short detection delay shall cover the bridge                                                           |  |
|                                            |      |    |                |                                | switching time. 0 will work for most applications.                                                         |  |
|                                            |      |    |                |                                | (Reset Default = 0)                                                                                        |  |
|                                            |      |    |                | Bit                            | DRV_CONF                                                                                                   |  |
|                                            |      |    |                | 40                             | BBMTIME:                                                                                                   |  |
|                                            |      |    |                |                                | Break-Before make delay                                                                                    |  |
| w                                          |      |    |                |                                | 0=shortest (100ns) 16 (200ns) 24=longest (375ns)                                                           |  |
|                                            | 0x0A | 22 | DRV_CONF       |                                | >24 not recommended, use <i>BBMCLKS</i> instead                                                            |  |
|                                            |      |    | _              |                                | Hint: Choose the lowest setting safely sovering the                                                        |  |
|                                            |      |    |                |                                | <i>Hint:</i> Choose the lowest setting safely covering the switching event in order to avoid bridge cross- |  |
|                                            |      |    |                |                                | conduction. Add roughly 30% of reserve.                                                                    |  |
|                                            |      |    |                |                                | (Reset Default = 0)                                                                                        |  |
|                                            | I    | 1  | 1              | I                              | ······································                                                                     |  |

| GENERAL CONFIGURATION REGISTERS (0x000x0F) |      |    |          |                         |                                                                                                                                                                                                                                                          |
|--------------------------------------------|------|----|----------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R/W                                        | Addr | n  | Register | Description I bit names |                                                                                                                                                                                                                                                          |
|                                            |      |    |          | 118                     | BBMCLKS:<br>015: Digital BBM time in clock cycles (typ. 83ns).<br>The longer setting rules (BBMTIME vs. BBMCLKS).<br>(Reset Default: OTP 4 or 2)<br>OTSELECT:<br>Selection of over temperature level for bridge disable,                                 |
|                                            |      |    |          |                         | switch on after cool down to 120°C / OTPW level.<br>00: 150°C<br>01: 143°C<br>10: 136°C (not recommended when VSA > 24V)<br>11: 120°C (not recommended, no hysteresis)                                                                                   |
|                                            |      |    |          |                         | <i>Hint:</i> Adapt overtemperature threshold as required to protect the MOSFETs or other components on the PCB. ( <i>Reset Default = %00</i> )                                                                                                           |
|                                            |      |    |          | 1918                    | DRVSTRENGTH:<br>Selection of gate driver current. Adapts the gate driver<br>current to the gate charge of the external MOSFETs.<br>00: weak<br>01: weak+TC (medium above OTPW level)                                                                     |
|                                            |      |    |          |                         | 10: medium<br>11: strong                                                                                                                                                                                                                                 |
|                                            |      |    |          | 2120                    | Hint: Choose the lowest setting giving slopes <100ns.<br>(Reset Default = %10)<br>FILT_ISENSE:<br>Filter time constant of sense amplifier to suppress                                                                                                    |
|                                            |      |    |          |                         | ringing and coupling from second coil operation<br>00: low - 100ns<br>01: - 200ns<br>10: - 300ns                                                                                                                                                         |
|                                            |      |    |          |                         | 10: – 500ns<br>11: high– 400ns<br><i>Hint:</i> Increase setting if motor chopper noise occurs                                                                                                                                                            |
|                                            |      |    |          | 7.0                     | due to cross-coupling of both coils.<br>(Reset Default = %00)                                                                                                                                                                                            |
|                                            |      |    | GLOBAL   | 70                      | Global scaling of Motor current. This value is multiplied<br>to the current scaling in order to adapt a drive to a<br>certain motor type. This value should be chosen before<br>tuning other settings, because it also influences<br>chopper hysteresis. |
| W                                          | 0x0B | 8  | SCALER   |                         | 0: Full Scale (or write 256)<br>1 31: Not allowed for operation<br>32 255: 32/256 255/256 of maximum current.                                                                                                                                            |
|                                            |      |    | OFFSET   | 158                     | Hint: Values >128 recommended for best results<br>(Reset Default = 0)<br>Offset calibration result phase A (signed)                                                                                                                                      |
| R                                          | 0x0C | 16 | READ     | 70                      | Offset calibration result phase B (signed)                                                                                                                                                                                                               |

# published by WWW.SKYTECH.IR

#### 6.1.1 OTP\_READ – OTP configuration memory

The OTP memory holds power up defaults for certain registers. All OTP memory bits are cleared to 0 by default. Programming only can set bits, clearing bits is not possible. Factory tuning of the clock frequency affects *otp*0.0 to *otp*0.4. The state of these bits therefore may differ between individual ICs.

| 0x07 | : OTP_READ | - OTP MEMORY MAP |                                                           |
|------|------------|------------------|-----------------------------------------------------------|
| Bit  | Name       | Function         | Comment                                                   |
| 7    | otp0.7     | otp_TBL          | Reset default for TBL:                                    |
|      |            |                  | 0: <i>TBL</i> =%10 (-3µs)                                 |
|      |            |                  | 1: <i>TBL</i> =%01 (-2µs)                                 |
| 6    | otp0.6     | otp_BBM          | Reset default for DRVCONF.BBMCLKS                         |
|      |            |                  | 0: BBMCLKS=4                                              |
|      |            |                  | 1: BBMCLKS=2                                              |
| 5    | otp0.5     | otp_S2_LEVEL     | Reset default for Short detection Levels:                 |
|      |            |                  | 0: S2G_LEVEL = S2VS_LEVEL = 6                             |
|      |            |                  | 1: S2G_LEVEL = S2VS_LEVEL = 12                            |
| 4    | otp0.4     | OTP_FCLKTRIM     | Reset default for FCLKTRIM                                |
| 3    | otp0.3     |                  | 0: lowest frequency setting                               |
| 2    | otp0.2     |                  | 31: highest frequency setting                             |
| 1    | otp0.1     |                  | Attention: This value is pre-programmed by factory clock  |
| 0    | otp0.0     |                  | trimming to the default clock frequency of 12MHz and      |
|      |            |                  | differs between individual ICs! It should not be altered. |



www.trinamic.com

## 6.2 Velocity Dependent Driver Feature Control Register Set

| R/W | Addr | n  | Register   | Descriptio                | n I bit names                                                                                |
|-----|------|----|------------|---------------------------|----------------------------------------------------------------------------------------------|
|     |      | •• |            | Bit                       | IHOLD_IRUN - Driver current control                                                          |
|     |      |    |            | 40                        | IHOLD                                                                                        |
|     |      |    |            | 40                        | Standstill current (0=1/3231=32/32)                                                          |
|     |      |    |            |                           | In combination with StealthChop mode, setting                                                |
|     |      |    |            |                           |                                                                                              |
|     |      |    |            |                           | <i>IHOLD</i> =0 allows to choose freewheeling or coil short circuit for motor stand still.   |
|     |      |    |            | 17.0                      |                                                                                              |
|     |      |    |            | 128                       | IRUN                                                                                         |
|     |      | -  |            |                           | Motor run current (0=1/3231=32/32)                                                           |
|     |      | 5  |            |                           | West Charge and an interview in a way that an and                                            |
| 14/ | 0.10 | +  |            |                           | Hint: Choose sense resistors in a way, that normal                                           |
| W   | 0x10 | 5  | IHOLD_IRUN | 10.14                     | IRUN is 16 to 31 for best microstep performance.                                             |
|     |      | +  |            | 1916                      | IHOLDDELAY                                                                                   |
|     |      | 4  |            |                           | Controls the number of clock cycles for motor                                                |
|     |      |    |            |                           | power down after a motion as soon as standstill is                                           |
|     |      |    |            |                           | detected (stst=1) and TPOWERDOWN has expired.                                                |
|     |      |    |            |                           | The smooth transition avoids a motor jerk upon                                               |
|     |      |    |            |                           | power down.                                                                                  |
|     |      |    |            |                           |                                                                                              |
|     |      |    |            |                           | 0: instant power down                                                                        |
|     |      |    |            |                           | 115: Delay per current reduction step in multiple                                            |
|     |      |    |            |                           | of 2^18 clocks                                                                               |
|     |      |    |            |                           | OWN sets the delay time after stand still (stst) of the                                      |
|     |      |    |            | motor to r                | motor current power down. Time range is about 0 to                                           |
|     |      |    | TPOWER     | 4 seconds.                |                                                                                              |
| W   | 0x11 | 8  | DOWN       | Attention:                | A minimum setting of 2 is required to allow                                                  |
|     |      |    | DOVVIV     | automatic                 | tuning of StealthChop PWM_OFFS_AUTO.                                                         |
|     |      |    |            | Reset Defa                | ult = 10                                                                                     |
|     |      |    |            | 0((2^8)-1)                | * 2^18 t <sub>CLK</sub>                                                                      |
|     |      |    |            | Actual me                 | asured time between two 1/256 microsteps derived                                             |
|     | ,    |    |            |                           | step input frequency in units of 1/fCLK. Measured ^20)-1 in case of overflow or stand still. |
|     |      |    |            | ALL TSTEP                 | related thresholds use a hysteresis of 1/16 of the                                           |
|     |      |    |            |                           | alue to compensate for jitter in the clock or the step                                       |
|     |      |    |            |                           | The flag <i>small_hysteresis</i> modifies the hysteresis to                                  |
|     |      |    |            |                           | value of 1/32.                                                                               |
|     |      |    |            | ( <i>Txxx</i> *15/16      |                                                                                              |
|     |      |    |            | 100                       | 2)-1 is used as a second compare value for each                                              |
|     |      |    |            |                           | n value.                                                                                     |
| р   | 0.12 | 20 | TETED      |                           |                                                                                              |
| R   | 0x12 | 20 | TSTEP      |                           | ns, that the lower switching velocity equals the                                             |
|     |      |    |            |                           | setting, but the upper switching velocity is higher as                                       |
|     |      |    |            | defined by                | the hysteresis setting.                                                                      |
|     |      |    |            | 14/1                      | 1                                                                                            |
| ļ   |      |    |            |                           | king with the motion controller, the measured TSTEP                                          |
|     |      |    |            |                           | n velocity V is in the range                                                                 |
|     |      |    |            | (2 <sup>∠4</sup> / V) ≤ 7 | ISTEP ≤ 2 <sup>24</sup> / V - 1.                                                             |
| ļ   |      |    |            |                           |                                                                                              |
|     |      |    |            |                           | mode TSTEP will not show the mean velocity of the                                            |
|     |      |    |            |                           | t the velocities for each microstep, which may not be                                        |
|     |      | 1  | 1          | 1                         |                                                                                              |
|     |      |    |            |                           | I thus does not represent the real motor velocity in is slower than the target velocity.     |

www.trinamic.com

| W       0x14       20       TCOOLTHRS       Set this parameter to disable CoolStep at low speeds, where cannot work reliably. The stop on stall function (enable vising internal motion controller) and the signal become enabled when exceeding this velocity non-DcStep mode, it becomes disabled again once the velocitable below this threshold.         W       0x14       20       TCOOLTHRS       TCOOLTHRS         V       0x15       20       THIGH       This velocity setting allows velocity dependent swit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |           | dent d  | 1                | ONTROL REGISTER SET (0x100x1F)                                                                                                                                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|---------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| W       0x13       20       TPWMTHRS       TSTEP ≥ TPWMTHRS         StealthChop PWM mode is enabled, if configured       - DcStep is disabled         Doctop is disabled       This is the lower threshold velocity for switching on sn energy CoolStep and StallGuard feature. (unsigned)         W       0x14       20       TCOOLTHRS         W       0x14       20       TCOOLTHRS         Set this parameter to disable CoolStep at low speeds, when cannot work reliably. The stop on stall function (enable visg. stop when using internal motion controller) and the soutput signal become enabled when exceeding this velocity non-DcStep mode, it becomes disabled again once the velocitation of the stop on stall function (enable visg. stop when using internal motion controller) and the soutput signal become enabled, if configured         W       0x14       20       TCOOLTHRS         TCOOLTHRS       TSTEP ≥ THIGH:       - CoolStep is enabled, if configured         - Stall output signal (DIAGO/1) is enabled, if configured       - Stall output signal (DIAGO/1) is enabled, if configured         - Stall detection feature becomes switched off for electrical periods whenever passing THIGH threshold compensate for the effect of switching modes.         W       0x15       20       THIGH         THIGH       - CoolStep is disabled (motor runs with normal cur scale)         - StealthChop voltage PWM mode is disabled       - If vhighchm is set, the chopper switches to ch with TFD-0 (constant off time wit                                                                                                                                                                                                                                   | R/W    | Addr      | n       | Register         |                                                                                                                                                                                                                                                                                                                    |
| W       0x14       20       TCOOLTHRS       Set this parameter to disable CoolStep at low speeds, where cannot work reliably. The stop on stall function (enable vising internal motion controller) and the sig_stop when using internal motion controller) and the signal become enabled when exceeding this velocity is non-DcStep mode, it becomes disabled again once the velocitalls below this threshold.         W       0x14       20       TCOOLTHRS       If TCOOLTHRS is TSTEP > THIGH:       -       CoolStep is enabled, if configured         -       Stall output signal (DIAGO/1) is enabled, if configured       -       Stall output signal (DIAGO/1) is enabled, if configured         -       Stall output signal (DIAGO/1) is enabled, if configured       -       Stall output signal (DIAGO/1) is enabled, if configured         W       0x15       20       THIGH       TSTEP > THIGH:       -         -       CoolStep is disabled (motor runs with normal curriscale)       -       StealthChop voltage PWM mode is disabled         W       0x15       20       THIGH       -       CoolStep is disabled (motor runs with normal curriscale) <tr< td=""><td>W</td><td>0x13</td><td>20</td><td>TPWMTHRS</td><td>TSTEP ≥ TPWMTHRS<br/>- StealthChop PWM mode is enabled, if configured</td></tr<> | W      | 0x13      | 20      | TPWMTHRS         | TSTEP ≥ TPWMTHRS<br>- StealthChop PWM mode is enabled, if configured                                                                                                                                                                                                                                               |
| W       0x14       20       TCOOLTHRS       sg_stop when using internal motion controller) and the soutput signal become enabled when exceeding this velocity non-DcStep mode, it becomes disabled again once the velocitation falls below this threshold.         W       0x14       20       TCOOLTHRS       TCOOLTHES       TCOOLTHES       TCOOLTHES       TCOOLTHES <td></td> <td></td> <td></td> <td></td> <td>Set this parameter to disable CoolStep at low speeds, where it</td>                                                                                                                                                                                                                                                                                   |        |           |         |                  | Set this parameter to disable CoolStep at low speeds, where it                                                                                                                                                                                                                                                     |
| W       0x14       20       TCOOLTHRS       falls below this threshold.         TCOOLTHRS ≥ TSTEP ≥ THIGH:       -       CoolStep is enabled, if configured         -       StealthChop voltage PWM mode is disabled         TCOOLTHRS ≥ TSTEP       -       Stop on stall is enabled, if configured         -       Stop on stall is enabled, if configured       -         -       Stop on stall is enabled, if configured       -         -       Stall output signal (DIAG0/1) is enabled, if configured       -         -       Stall output signal (DIAG0/1) is enabled, if configured       -         -       This velocity setting allows velocity dependent switching a different chopper mode and fullstepping to maximize tore (unsigned)         The stall detection feature becomes switched off for electrical periods whenever passing THIGH threshold compensate for the effect of switching modes.         TSTEP ≤ THIGH:       -       CoolStep is disabled (motor runs with normal curriscale)         -       StealthChop voltage PWM mode is disabled       -         -       If vhighchm is set, the chopper switches to chowith TFD=0 (constant off time with slow decay, only)       -         -       If vhighfs is set, the motor operates in fullstep m and the stall detection becomes switched over                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |           |         |                  | <i>sg_stop</i> when using internal motion controller) and the stall output signal become enabled when exceeding this velocity. In                                                                                                                                                                                  |
| <ul> <li>W 0x15</li> <li>20</li> <li>THIGH</li> <li>- CoolStep is enabled, if configured</li> <li>- Stall output signal (DIAG0/1) is enabled, if configured</li> <li>- Stall output signal (DIAG0/1) is enabled, if configured</li> <li>- Stall output signal (DIAG0/1) is enabled, if configured</li> <li>- Stall output signal (DIAG0/1) is enabled, if configured</li> <li>- Stall output signal (DIAG0/1) is enabled, if configured</li> <li>- Stall output signal (DIAG0/1) is enabled, if configured</li> <li>- Stall output signal (DIAG0/1) is enabled, if configured</li> <li>a different chopper mode and fullstepping to maximize toro (unsigned)</li> <li>The stall detection feature becomes switched off for electrical periods whenever passing <i>THIGH</i> threshold compensate for the effect of switching modes.</li> <li><i>TSTEP</i> ≤ <i>THIGH</i>:</li> <li>- CoolStep is disabled (motor runs with normal curl scale)</li> <li>- StealthChop voltage PWM mode is disabled</li> <li>- If <i>vhighchm</i> is set, the chopper switches to <i>chu</i> with <i>TFD</i>=0 (constant off time with slow decay, only)</li> <li>- If <i>vhighfs</i> is set, the motor operates in fullstep m and the stall detection becomes switched over</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | w      | 0x14      | 20      | TCOOLTHRS        |                                                                                                                                                                                                                                                                                                                    |
| <ul> <li>W 0x15 20 THIGH</li> <li>Stop on stall is enabled, if configured</li> <li>Stall output signal (DIAG0/1) is enabled, if configured</li> <li>This velocity setting allows velocity dependent switching is a different chopper mode and fullstepping to maximize toro (unsigned)</li> <li>The stall detection feature becomes switched off for electrical periods whenever passing THIGH threshold compensate for the effect of switching modes.</li> <li>TSTEP ≤ THIGH:         <ul> <li>CoolStep is disabled (motor runs with normal curriscale)</li> <li>StealthChop voltage PWM mode is disabled</li> <li>If vhighchm is set, the chopper switches to chiwith TFD=0 (constant off time with slow decay, only)</li> <li>If vhighfs is set, the motor operates in fullstep m and the stall detection becomes switched over</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |           |         |                  | - CoolStep is enabled, if configured                                                                                                                                                                                                                                                                               |
| W       0x15       20       THIGH       a different chopper mode and fullstepping to maximize toro (unsigned)         W       0x15       20       THIGH       The stall detection feature becomes switched off for electrical periods whenever passing THIGH threshold compensate for the effect of switching modes.         TSTEP ≤ THIGH:       -       CoolStep is disabled (motor runs with normal curriscale)         -       StealthChop voltage PWM mode is disabled         -       If vhighchm is set, the chopper switches to chiwith TFD=0 (constant off time with slow decay, only)         -       If vhighfs is set, the motor operates in fullstep m and the stall detection becomes switched over                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        |           |         |                  | <ul> <li>Stop on stall is enabled, if configured</li> <li>Stall output signal (DIAG0/1) is enabled, if configured</li> </ul>                                                                                                                                                                                       |
| <ul> <li>W 0x15 20 IHIGH</li> <li>CoolStep is disabled (motor runs with normal curriscale)</li> <li>StealthChop voltage PWM mode is disabled</li> <li>If vhighchm is set, the chopper switches to chrwith TFD=0 (constant off time with slow decay, only</li> <li>If vhighfs is set, the motor operates in fullstep m and the stall detection becomes switched over</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |        |           |         |                  | The stall detection feature becomes switched off for 2-3 electrical periods whenever passing <i>THIGH</i> threshold to                                                                                                                                                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | W      | 0x15      | 20      | THIGH            | <ul> <li>CoolStep is disabled (motor runs with normal current scale)</li> <li>StealthChop voltage PWM mode is disabled</li> <li>If vhighchm is set, the chopper switches to chm=1 with TFD=0 (constant off time with slow decay, only).</li> <li>If vhighfs is set, the motor operates in fullstep mode</li> </ul> |
| Destep statt detection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |           |         |                  | and the stall detection becomes switched over to DcStep stall detection.                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Min    |           |         |                  |                                                                                                                                                                                                                                                                                                                    |
| Microstep velocity time reference t for velocities: TSTEP = f <sub>CLK</sub> / f <sub>STEP</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Micros | tep veloc | ity tim | e reference t fo | or velocities: ISIEP = t <sub>CLK</sub> / t <sub>STEP</sub>                                                                                                                                                                                                                                                        |

www.trinamic.com

## 6.3 Ramp Generator Registers

## 6.3.1 Ramp Generator Motion Control Register Set

| RAMP | RAMP GENERATOR MOTION CONTROL REGISTER SET (0x200x2D) |    |          |                                                                                                                                                                                                                                                                                           |                             |  |  |
|------|-------------------------------------------------------|----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--|--|
| R/W  | Addr                                                  | n  | Register | Description I bit names                                                                                                                                                                                                                                                                   | Range [Unit]                |  |  |
| RW   | 0x20                                                  | 2  | RAMPMODE | <ul> <li>RAMPMODE:</li> <li>O: Positioning mode (using all A, D and V parameters)</li> <li>1: Velocity mode to positive VMAX (using AMAX acceleration)</li> <li>2: Velocity mode to negative VMAX (using AMAX acceleration)</li> <li>3: Hold mode (velocity remains unchanged,</li> </ul> | 03                          |  |  |
|      |                                                       |    |          | unless stop event occurs)                                                                                                                                                                                                                                                                 |                             |  |  |
| RW   | 0x21                                                  | 32 | XACTUAL  | Actual motor position (signed)<br><i>Hint:</i> This value normally should only be<br>modified, when homing the drive. In<br>positioning mode, modifying the register<br>content will start a motion.                                                                                      | -2^31<br>+(2^31)-1          |  |  |
| R    | 0x22                                                  | 24 | VACTUAL  | Actual motor velocity from ramp generator<br>(signed)<br>The sign matches the motion direction. A<br>negative sign means motion to lower<br>XACTUAL.                                                                                                                                      | +-(2^23)-1<br>[µsteps / t]  |  |  |
| w    | 0x23                                                  | 18 | VSTART   | Motor start velocity (unsigned)<br>For universal use, set VSTOP ≥ VSTART. This is<br>not required if the motion distance is sufficient<br>to ensure deceleration from VSTART to VSTOP.                                                                                                    | 0(2^18)-1<br>[µsteps / t]   |  |  |
| W    | 0x24                                                  | 16 | A1       | First acceleration between VSTART and V1 (unsigned)                                                                                                                                                                                                                                       | 0(2^16)-1<br>[µsteps / ta²] |  |  |
| w    | 0x25                                                  | 20 | V1       | First acceleration <i>1</i> deceleration phase<br>threshold velocity (unsigned)<br>0: Disables <i>A1</i> and <i>D1</i> phase, use <i>AMAX</i> , <i>DMAX</i>                                                                                                                               | 0(2^20)-1<br>[µsteps / t]   |  |  |
|      |                                                       |    |          | only                                                                                                                                                                                                                                                                                      |                             |  |  |
| w    | 0x26                                                  | 16 | АМАХ     | Second acceleration between V1 and VMAX<br>(unsigned)<br>This is the acceleration and deceleration value<br>for velocity mode.                                                                                                                                                            | 0(2^16)-1<br>[µsteps / ta²] |  |  |
| W    | 0x27                                                  | 23 | VMAX     | Motion ramp target velocity (for positioning<br>ensure VMAX ≥ VSTART) (unsigned)<br>This is the target velocity in velocity mode. It<br>can be changed any time during a motion.                                                                                                          | 0(2^23)-512<br>[µsteps / t] |  |  |
| W    | 0x28                                                  | 16 | DMAX     | Deceleration between VMAX and V1 (unsigned)                                                                                                                                                                                                                                               | 0(2^16)-1<br>[µsteps / ta²] |  |  |
| W    | 0x2A                                                  | 16 | D1       | Deceleration between V1 and VSTOP<br>(unsigned)<br>Attention: Do not set 0 in positioning mode,<br>even if V1=0!                                                                                                                                                                          | 1(2^16)-1<br>[µsteps / ta²] |  |  |

www.trinamic.com

| RAMP | RAMP GENERATOR MOTION CONTROL REGISTER SET (0x200x2D) |    |           |                                                                                                                                                                                                                                                                                                                                                                                              |                                                 |  |  |
|------|-------------------------------------------------------|----|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|--|--|
| R/W  | Addr                                                  | n  | Register  | Description I bit names                                                                                                                                                                                                                                                                                                                                                                      | Range [Unit]                                    |  |  |
| W    | 0x2B                                                  | 18 | VSTOP     | Motor stop velocity (unsigned)<br><i>Hint:</i> Set VSTOP ≥ VSTART to allow positioning<br>for short distances<br><i>Attention: Do not set 0 in positioning mode,</i><br><i>minimum</i> 10 recommend!                                                                                                                                                                                         | 1(2^18)-1<br>[µsteps / t]<br>Reset<br>Default=1 |  |  |
| w    | 0x2C                                                  | 16 | TZEROWAIT | Defines the waiting time after ramping down<br>to zero velocity before next movement or<br>direction inversion can start. Time range is<br>about 0 to 2 seconds.<br>This setting avoids excess acceleration e.g.                                                                                                                                                                             | 0(2^16)-1 *<br>512 t <sub>CLK</sub>             |  |  |
|      |                                                       |    |           | from VSTOP to -VSTART.<br>Target position for ramp mode (signed). Write<br>a new target position to this register in order<br>to activate the ramp generator positioning in<br>RAMPMODE=0. Initialize all velocity,<br>acceleration and deceleration parameters<br>before.                                                                                                                   | -2^31<br>+(2^31)-1                              |  |  |
| RW   | 0x2D                                                  | 32 | XTARGET   | <ul> <li><i>Hint:</i> The position is allowed to wrap around, thus, <i>XTARGET</i> value optionally can be treated as an unsigned number.</li> <li><i>Hint:</i> The maximum possible displacement is +/-((2^31)-1).</li> <li><i>Hint:</i> When increasing V1, D1 or DMAX during a motion, rewrite XTARGET afterwards in order to trigger a second acceleration phase, if desired.</li> </ul> |                                                 |  |  |



www.trinamic.com

## 6.3.2 Ramp Generator Driver Feature Control Register Set

| RAMP GENERATOR DRIVER FEATURE CONTROL REGISTER SET (0x300x36) |      |    |           |                                                                                                                                                                                                                                                              |
|---------------------------------------------------------------|------|----|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R/W                                                           | Addr | n  | Register  | Description I bit names                                                                                                                                                                                                                                      |
|                                                               |      |    |           | Automatic commutation DcStep becomes enabled above velocity VDCMIN (unsigned) (only when using internal ramp generator, not for STEP/DIR interface – in STEP/DIR mode, DcStep becomes enabled by the external signal DCEN)                                   |
|                                                               |      |    |           | In this mode, the actual position is determined by the sensor-<br>less motor commutation and becomes fed back to XACTUAL. In<br>case the motor becomes heavily loaded, VDCMIN also is used<br>as the minimum step velocity. Activate stop on stall (sg_stop) |
| W                                                             | 0x33 | 23 | VDCMIN    | to detect step loss.                                                                                                                                                                                                                                         |
|                                                               |      |    |           | 0: Disable, DcStep off                                                                                                                                                                                                                                       |
|                                                               |      |    |           | $ VACT  \ge VDCMIN \ge 256$ :                                                                                                                                                                                                                                |
|                                                               |      |    |           | - Triggers the same actions as exceeding THIGH setting.                                                                                                                                                                                                      |
|                                                               |      |    |           | - Switches on automatic commutation DcStep                                                                                                                                                                                                                   |
|                                                               |      |    |           | Hint: Also set DCCTRL parameters in order to operate DcStep.                                                                                                                                                                                                 |
|                                                               |      |    |           | (Only bits 22 8 are used for value and for comparison)                                                                                                                                                                                                       |
|                                                               |      |    | SW MODE   | Switch mode configuration                                                                                                                                                                                                                                    |
| RW                                                            | 0x34 | 12 | 511_11002 | See separate table!                                                                                                                                                                                                                                          |
| R+                                                            | 0x35 | 14 | RAMP_STAT | Ramp status and switch event status                                                                                                                                                                                                                          |
| WC                                                            | UXDD | 14 |           | See separate table!                                                                                                                                                                                                                                          |
|                                                               |      |    |           | Ramp generator latch position, latches XACTUAL upon a                                                                                                                                                                                                        |
| р                                                             | 026  | 22 | VIATCH    | programmable switch event (see SW_MODE).                                                                                                                                                                                                                     |
| R                                                             | 0x36 | 32 | XLATCH    | Hint: The encoder position can be latched to ENC_LATCH                                                                                                                                                                                                       |
|                                                               |      |    |           | together with XLATCH to allow consistency checks.                                                                                                                                                                                                            |
|                                                               |      |    |           | together with ALArch to allow consistency checks.                                                                                                                                                                                                            |

Time reference t for velocities: t =  $2^24 / f_{CLK}$ Time reference ta<sup>2</sup> for accelerations: ta<sup>2</sup> =  $2^41 / (f_{CLK})^2$ 



www.trinamic.com

| 0x34   | : SW_MODE - REFER                    | RENCE SWITCH AND STALLGUARD2 EVENT CONFIGURATION REGISTER                                                                                                                                                                                                                                                                    |
|--------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit    | Name                                 | Comment                                                                                                                                                                                                                                                                                                                      |
| 11     | en_softstop                          | 0: Hard stop<br>1: Soft stop                                                                                                                                                                                                                                                                                                 |
|        |                                      | The soft stop mode always uses the deceleration ramp settings <i>DMAX</i> , V1, <i>D1</i> , <i>VSTOP</i> and <i>TZEROWAIT</i> for stopping the motor. A stop occurs when the velocity sign matches the reference switch position (REFL for negative velocities, REFR for positive velocities) and the respective switch stop |
|        |                                      | function is enabled.<br>A hard stop also uses <i>TZEROWAIT</i> before the motor becomes released.                                                                                                                                                                                                                            |
|        |                                      |                                                                                                                                                                                                                                                                                                                              |
|        |                                      | Attention: Do not use soft stop in combination with StallGuard2. Use soft stop for StealthChop operation <u>at high velocity</u> . In this case, hard stop must be avoided, as it could result in severe overcurrent.                                                                                                        |
| 10     | sg_stop                              | 1: Enable stop by StallGuard2 (also available in DcStep mode). Disable to                                                                                                                                                                                                                                                    |
|        |                                      | release motor after stop event. Program TCOOLTHRS for velocity threshold.                                                                                                                                                                                                                                                    |
|        |                                      |                                                                                                                                                                                                                                                                                                                              |
|        |                                      | Hint: Do not enable during motor spin-up, wait until the motor velocity                                                                                                                                                                                                                                                      |
|        |                                      | exceeds a certain value, where StallGuard2 delivers a stable result. This                                                                                                                                                                                                                                                    |
| 0      | an latah angadan                     | velocity threshold should be programmed using TCOOLTHRS.                                                                                                                                                                                                                                                                     |
| 9<br>8 | en_latch_encoder<br>latch_r_inactive | <ol> <li>1: Latch encoder position to ENC_LATCH upon reference switch event.</li> <li>1: Activates latching of the position to XLATCH upon an inactive going</li> </ol>                                                                                                                                                      |
| 0      | lulch_1_muchve                       | edge on the right reference switch input REFR. The active level is defined                                                                                                                                                                                                                                                   |
|        |                                      | by pol_stop_r.                                                                                                                                                                                                                                                                                                               |
| 7      | latch_r_active                       | 1: Activates latching of the position to <i>XLATCH</i> upon an active going edge<br>on the right reference switch input REFR.                                                                                                                                                                                                |
|        |                                      | <i>Hint:</i> Activate <i>latch_r_active</i> to detect any spurious stop event by reading                                                                                                                                                                                                                                     |
| 6      | latch_l_inactive                     | <pre>status_latch_r. 1: Activates latching of the position to XLATCH upon an inactive going</pre>                                                                                                                                                                                                                            |
| 0      | luttin_t_muttive                     | edge on the left reference switch input REFL. The active level is defined                                                                                                                                                                                                                                                    |
|        |                                      | by pol_stop_l.                                                                                                                                                                                                                                                                                                               |
| 5      | latch_l_active                       | 1: Activates latching of the position to XLATCH upon an active going edge                                                                                                                                                                                                                                                    |
| _      |                                      | on the left reference switch input REFL.                                                                                                                                                                                                                                                                                     |
|        |                                      |                                                                                                                                                                                                                                                                                                                              |
|        |                                      | <i>Hint:</i> Activate <i>latch_l_active</i> to detect any spurious stop event by reading                                                                                                                                                                                                                                     |
|        |                                      | status_latch_l.                                                                                                                                                                                                                                                                                                              |
| 4      | swap_lr                              | 1: Swap the left and the right reference switch input REFL and REFR                                                                                                                                                                                                                                                          |
| 3      | pol_stop_r                           | Sets the active polarity of the right reference switch input                                                                                                                                                                                                                                                                 |
|        |                                      | 0=non-inverted, high active: a high level on REFR stops the motor                                                                                                                                                                                                                                                            |
| 2      | nol ston l                           | 1=inverted, low active: a low level on REFR stops the motor<br>Sets the active polarity of the left reference switch input                                                                                                                                                                                                   |
| 2      | pol_stop_l                           | 0=non-inverted, high active: a high level on REFL stops the motor                                                                                                                                                                                                                                                            |
|        |                                      | 1=inverted, low active: a low level on REFL stops the motor                                                                                                                                                                                                                                                                  |
| 1      | stop_r_enable                        | 1: Enables automatic motor stop during active right reference switch input                                                                                                                                                                                                                                                   |
| -      |                                      |                                                                                                                                                                                                                                                                                                                              |
| 0      |                                      | <i>Hint:</i> The motor restarts in case the stop switch becomes released.                                                                                                                                                                                                                                                    |
| 0      | stop_l_enable                        | 1: Enables automatic motor stop during active left reference switch input                                                                                                                                                                                                                                                    |
|        |                                      | Hint: The motor restarts in case the stop switch becomes released.                                                                                                                                                                                                                                                           |

## 6.3.2.1 SW\_MODE - Reference Switch & StallGuard2 Event Configuration Register

www.trinamic.com

#### 6.3.2.2 RAMP\_STAT - Ramp & Reference Switch Status Register

| 0x35:    | RAMP_ | STAT - RAMP AN        | D REFERENCE SWITCH STATUS REGISTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R/W      | Bit   | Name                  | Comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| R        | 13    | status_sg             | 1: Signals an active StallGuard2 input from the CoolStep driver or<br>from the DcStep unit, if enabled.<br><i>Hint:</i> When polling this flag, stall events may be missed – activate<br><i>sg_stop</i> to be sure not to miss the stall event.                                                                                                                                                                                                                                                                                                    |
| R+<br>WC | 12    | second_move           | 1: Signals that the automatic ramp required moving back in the opposite direction, e.g. due to on-the-fly parameter change (Write '1' to clear)                                                                                                                                                                                                                                                                                                                                                                                                    |
| R        | 11    | t_zerowait_<br>active | 1: Signals, that <i>TZEROWAIT</i> is active after a motor stop. During this time, the motor is in standstill.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| R        | 10    | vzero                 | 1: Signals, that the actual velocity is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| R        | 9     | position_<br>reached  | 1: Signals, that the target position is reached.<br>This flag becomes set while <i>XACTUAL</i> and <i>XTARGET</i> match.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| R        | 8     | velocity_<br>reached  | 1: Signals, that the target velocity is reached.<br>This flag becomes set while VACTUAL and VMAX match.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| R+<br>WC | 7     | event_pos_<br>reached | 1: Signals, that the target position has been reached ( <i>position_reached</i> becoming active).<br>(Write '1' to clear flag and interrupt condition)<br>This bit is ORed to the <i>interrupt</i> output signal.                                                                                                                                                                                                                                                                                                                                  |
| R+<br>WC | 6     | event_stop_<br>sg     | 1: Signals an active StallGuard2 stop event.<br>Resetting the register will clear the stall condition and the motor<br>may re-start motion, unless the motion controller has been stopped.<br>(Write '1' to clear flag and interrupt condition)<br>This bit is ORed to the <i>interrupt output</i> signal.                                                                                                                                                                                                                                         |
| R        | 5     | event_stop_r          | 1: Signals an active stop right condition due to stop switch.<br>The stop condition and the interrupt condition can be removed by<br>setting <i>RAMP_MODE</i> to hold mode or by commanding a move to the<br>opposite direction. In <i>soft_stop</i> mode, the condition will remain<br>active until the motor has stopped motion into the direction of the<br>stop switch. Disabling the stop switch or the stop function also<br>clears the flag, but the motor will continue motion.<br>This bit is ORed to the <i>interrupt output</i> signal. |
|          | 4     | event_stop_l          | 1: Signals an active stop left condition due to stop switch.<br>The stop condition and the interrupt condition can be removed by setting <i>RAMP_MODE</i> to hold mode or by commanding a move to the opposite direction. In <i>soft_stop</i> mode, the condition will remain active until the motor has stopped motion into the direction of the stop switch. Disabling the stop switch or the stop function also clears the flag, but the motor will continue motion.<br>This bit is ORed to the <i>interrupt output</i> signal.                 |
| R+<br>WC | 3     | status_latch_r        | 1: Latch right ready<br>(enable position latching using SW_MODE settings<br>latch_r_active or latch_r_inactive)<br>(Write '1' to clear)                                                                                                                                                                                                                                                                                                                                                                                                            |
|          | 2     | status_latch_l        | 1: Latch left ready<br>(enable position latching using SW_MODE settings<br><i>latch_l_active</i> or <i>latch_l_inactive</i> )<br>(Write '1' to clear)                                                                                                                                                                                                                                                                                                                                                                                              |
| R        | 1     | status_stop_r         | Reference switch right status (1=active)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          | 0     | status_stop_l         | Reference switch left status (1=active)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

www.trinamic.com

#### 44

## 6.4 Encoder Registers

Attention:

The encoder interface is not available in Step&Direction mode, as the encoder pins serve a different function in that mode.

| ENCODER REGISTER SET (0x380x3C) |        |    |                   |                                                                                                                                                                                            |                                                                         |  |
|---------------------------------|--------|----|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|--|
| R/W                             | Addr   | n  | Register          | Description I bit names                                                                                                                                                                    | Range [Unit]                                                            |  |
| RW                              | 0x38   | 11 | ENCMODE           | Encoder configuration and use of N channel See separate table!                                                                                                                             |                                                                         |  |
| RW                              | 0x39   | 32 | X_ENC             | Actual encoder position (signed)                                                                                                                                                           | -2^31<br>+(2^31)-1                                                      |  |
| W                               | 0x3A   | 32 | ENC CONST         | Accumulation constant (signed)<br>16 bit integer part, 16 bit fractional part<br>X_ENC accumulates<br>+/- ENC_CONST / (2^16*X_ENC) (binary)<br>or                                          | binary:<br>± [µsteps/2^16]<br>±(0<br>32767.999847)<br>decimal:<br>±(0.0 |  |
|                                 | U.S.I. |    |                   | + <i>I</i> -ENC_CONST / (10 <sup>4</sup> *X_ENC) (decimal)<br>ENCMODE bit enc_sel_decimal switches<br>between decimal and binary setting.<br>Use the sign, to match rotation direction!    | 32767.9999)<br>reset default =<br>1.0 (=65536)                          |  |
| R+<br>WC                        | 0x3B   | 2  | ENC_STATUS        | Encoder status information<br>bit 0: <i>n_event</i><br>bit 1: <i>deviation_warn</i><br>1: Event detected.<br>To clear the status bit, write with a 1 bit at<br>the corresponding position. |                                                                         |  |
|                                 |        |    |                   | Deviation_warn cannot be cleared while a<br>warning still persists. Set ENC_DEVIATION<br>zero to disable.<br>Both bits are ORed to the <i>interrupt output</i><br>signal.                  |                                                                         |  |
| R                               | 0x3C   | 32 | ENC_LATCH         | Encoder position X_ENC latched on N event                                                                                                                                                  |                                                                         |  |
| w                               | 0x3D   | 20 | ENC_<br>DEVIATION | Maximum number of steps deviation<br>between encoder counter and XACTUAL for<br>deviation warning<br>Result in flag ENC_STATUS. <i>deviation_warn</i><br>0=Function is off.                | NIC                                                                     |  |

www.trinamic.com

## 6.4.1 ENCMODE - Encoder Register

| 0x38 | 0x38: ENCMODE – ENCODER REGISTER |        |                                                                      |  |  |  |
|------|----------------------------------|--------|----------------------------------------------------------------------|--|--|--|
| Bit  | Name                             | Comr   | nent                                                                 |  |  |  |
| 10   | enc_sel_decimal                  | 0      | Encoder prescaler divisor binary mode:                               |  |  |  |
|      |                                  |        | Counts ENC_CONST(fractional part) 165536                             |  |  |  |
|      |                                  | 1      | Encoder prescaler divisor decimal mode:                              |  |  |  |
|      |                                  |        | Counts in ENC_CONST(fractional part) /10000                          |  |  |  |
| 9    | latch_x_act                      |        | o latch XACTUAL position together with X_ENC.                        |  |  |  |
|      |                                  |        | is latching the ramp generator position upon an N channel event as   |  |  |  |
|      |                                  | select | ed by pos_edge and neg_edge.                                         |  |  |  |
| 8    | clr_enc_x                        | 0      | Upon N event, X_ENC becomes latched to ENC_LATCH only                |  |  |  |
|      |                                  | 1      | Latch and additionally clear encoder counter X_ENC at N-event        |  |  |  |
| 7    | neg_edge                         | np     | N channel event sensitivity                                          |  |  |  |
| 6    | pos_edge                         | 00     | N channel event is active during an active N event level             |  |  |  |
|      |                                  | 01     | N channel is valid upon active going N event                         |  |  |  |
|      |                                  | 10     | N channel is valid upon inactive going N event                       |  |  |  |
|      |                                  | 11     | N channel is valid upon active going and inactive going N event      |  |  |  |
| 5    | clr_once                         | 1: Lat | ch or latch and clear X_ENC on the next N event following the write  |  |  |  |
|      |                                  | acces  |                                                                      |  |  |  |
| 4    | clr_cont                         |        | ways latch or latch and clear X_ENC upon an N event (once per        |  |  |  |
|      |                                  |        | ution, it is recommended to combine this setting with edge sensitive |  |  |  |
|      |                                  | N eve  |                                                                      |  |  |  |
| 3    | ignore_AB                        | 0      | An N event occurs only when polarities given by                      |  |  |  |
|      |                                  |        | pol_N, pol_A and pol_B match.                                        |  |  |  |
|      |                                  | 1      | Ignore A and B polarity for N channel event                          |  |  |  |
| 2    | pol_N                            |        | es active polarity of N (0=low active, 1=high active)                |  |  |  |
| 1    | pol_B                            |        | red B polarity for an N channel event (0=neg., 1=pos.)               |  |  |  |
| 0    | pol_A                            | Requi  | red A polarity for an N channel event (0=neg., 1=pos.)               |  |  |  |



www.trinamic.com

## 6.5 Motor Driver Registers

| MICRO | STEPPING | CONTR       | ROL REGISTER SE                               | tt (0x600x6B)                                                                                                                                                                                                                                                                                                                                     |                                                                          |
|-------|----------|-------------|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| R/W   | Addr     | n           | Register                                      | Description I bit names                                                                                                                                                                                                                                                                                                                           | Range [Unit]                                                             |
| W     | 0x60     | 32          | MSLUT[0]<br>microstep<br>table entries<br>031 | Each bit gives the difference between entry x<br>and entry x+1 when combined with the cor-<br>responding <i>MSLUTSEL W</i> bits:<br>0: W= %00: -1<br>%01: +0                                                                                                                                                                                      | 32x 0 or 1<br>reset default=<br>sine wave<br>table                       |
|       | 0x61     | 7           | MSLUT[17]                                     | %10: +1<br>%11: +2<br>1: W= %00: +0<br>%01: +1<br>%10: +2<br>%11: +3                                                                                                                                                                                                                                                                              | 7x<br>32x 0 or 1<br>reset default=<br>sine wave<br>table                 |
| W     | <br>0x67 | x<br>32     | microstep<br>table entries<br>32255           | This is the differential coding for the first<br>quarter of a wave. Start values for CUR_A and<br>CUR_B are stored for MSCNT position 0 in<br>START_SIN and START_SIN90.<br>ofs31, ofs30,, ofs01, ofs00<br><br>ofs255, ofs254,, ofs225, ofs224                                                                                                    |                                                                          |
| W     | 0x68     | 32          | MSLUTSEL                                      | This register defines four segments within<br>each quarter <i>MSLUT</i> wave. Four 2 bit entries<br>determine the meaning of a 0 and a 1 bit in<br>the corresponding segment of <i>MSLUT</i> .<br><i>See separate table!</i>                                                                                                                      | 0 <x1<x2<x3<br>reset default=<br/>sine wave<br/>table</x1<x2<x3<br>      |
| W     | 0x69     | 8<br>+<br>8 | MSLUTSTART                                    | bit 7 0: START_SIN<br>bit 23 16: START_SIN90<br>START_SIN gives the absolute current at<br>microstep table entry 0.<br>START_SIN90 gives the absolute current for<br>microstep table entry at positions 256.<br>Start values are transferred to the microstep<br>registers CUR_A and CUR_B, whenever the<br>reference position MSCNT=0 is passed. | START_SIN<br>reset default<br>=0<br>START_SIN90<br>reset default<br>=247 |
| R     | 0x6A     | 10          | MSCNT                                         | Microstep counter. Indicates actual position<br>in the microstep table for CUR_A. CUR_B uses<br>an offset of 256 (2 phase motor).<br>Hint: Move to a position where MSCNT is<br>zero before re-initializing MSLUTSTART or<br>MSLUT and MSLUTSEL.                                                                                                  |                                                                          |
| R     | Ox6B     | 9<br>+<br>9 | MSCURACT                                      | bit 8 0:<br>CUR_A (signed):<br>Actual microstep current for<br>motor phase A as read from<br>MSLUT (not scaled by current)<br>bit 24 16:<br>CUR_B (signed):<br>Actual microstep current for<br>motor phase B as read from<br>MSLUT (not scaled by current)                                                                                        | +/-0255                                                                  |

www.trinamic.com

| DRIVE | R REGISTE | r set ( | (0x6C0x7F)     |                                                                                                                                                                                                                                            |                              |
|-------|-----------|---------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| R/W   | Addr      | n       | Register       | Description I bit names                                                                                                                                                                                                                    | Range [Unit]                 |
| RW    | 0x6C      | 32      | CHOPCONF       | chopper and driver configuration<br>See separate table!                                                                                                                                                                                    | reset default=<br>0x10410150 |
| W     | 0x6D      | 25      | COOLCONF       | CoolStep smart current control register<br>and StallGuard2 configuration<br>See separate table!                                                                                                                                            |                              |
|       |           |         |                | DcStep (DC) automatic commutation<br>configuration register (enable via pin DCEN<br>or via VDCMIN):<br>bit 9 0: DC_TIME: Upper PWM on time<br>limit for commutation (DC_TIME *<br>1/fcLk). Set slightly above effective<br>blank time TBL. |                              |
| w     | 0×6E      | 24      | DCCTRL         | bit 23 16: DC_SG: Max. PWM on time for<br>step loss detection using DcStep<br>StallGuard2 in DcStep mode.<br>(DC_SG * 16/f <sub>CLK</sub> )                                                                                                |                              |
|       |           |         |                | Set slightly higher than<br>DC_TIME/16<br>0=disable<br>Hint: Using a higher microstep resolution or                                                                                                                                        |                              |
|       |           |         |                | interpolated operation, DcStep delivers a<br>better StallGuard signal.<br>DC_SG is also available above VHIGH if<br>vhighfs is activated. For best result also set<br>vhighchm.                                                            |                              |
| R     | 0x6F      | 32      | DRV_<br>STATUS | StallGuard2 value and driver error flags<br>See separate table!                                                                                                                                                                            |                              |
| W     | 0x70      | 22      | PWMCONF        | Voltage PWM mode chopper configuration See separate table!                                                                                                                                                                                 | reset default=<br>0xC40C001E |
|       |           |         |                | Results of StealthChop amplitude regulator.<br>These values can be used to monitor<br>automatic PWM amplitude scaling (255=max.<br>voltage).                                                                                               |                              |
| R     | 0x71      | 9+8     | PWM_SCALE      | bit 7 0 PWM_SCALE_SUM:<br>Actual PWM duty cycle. This<br>value is used for scaling the<br>values CUR_A and CUR_B read<br>from the sine wave table.                                                                                         | 0255                         |
|       |           |         |                | bit 24 16 <i>PWM_SCALE_AUTO</i> :<br>9 Bit signed offset added to the<br>calculated PWM duty cycle. This<br>is the result of the automatic<br>amplitude regulation based on<br>current measurement.                                        | signed<br>-255+255           |
| R     | 0x72      | 8+8     | PWM_AUTO       | These automatically generated values can be<br>read out in order to determine a default /<br>power up setting for PWM_GRAD and<br>PWM_OFS.                                                                                                 |                              |
|       |           |         |                | bit 7 0 PWM_OFS_AUTO:<br>Automatically determined offset<br>value                                                                                                                                                                          | 0255                         |

www.trinamic.com

| DRIVE | DRIVER REGISTER SET (0x6C0x7F) |    |            |                                                                                                                                                                                                                                  |                  |  |  |
|-------|--------------------------------|----|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--|--|
| R/W   | Addr                           | n  | Register   | Description <i>I bit names</i>                                                                                                                                                                                                   | Range [Unit]     |  |  |
|       |                                |    |            | bit 23 16 PWM_GRAD_AUTO:<br>Automatically determingradient value                                                                                                                                                                 | 0255<br>ned      |  |  |
| R     | 0x73                           | 20 | LOST_STEPS | Number of input steps skipped due to hig<br>load in DcStep operation, if step input do<br>not stop when DC_OUT is low. This cour<br>wraps around after 2^20 steps. Counts up<br>down depending on direction. Only w<br>SDMODE=1. | bes<br>ter<br>or |  |  |

MICROSTEP TABLE CALCULATION FOR A SINE WAVE EQUIVALENT TO THE POWER ON DEFAULT

round 
$$\left(248 * sin\left(2 * PI * \frac{i}{1024} + \frac{PI}{1024}\right)\right) - 1$$

- *i*:[0... 255] is the table index
- The amplitude of the wave is 248. The resulting maximum positive value is 247 and the maximum negative value is -248.
- The round function rounds values from 0.5 to 1.4999 to 1



www.trinamic.com

| 0x68                                                                                                                                                                                                                                       | : MSLUTSEL        | - LOOK UP TABLE SEGMENT                                                                      | ATION DEFINITION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                                                                                                                                                        | Name              | Function                                                                                     | Comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit         31         30         29         28         27         26         25         24         23         22         21         20         19         18         17         16         15         14         13         12         11 | Name           X3 | Function         LUT segment 3 start         LUT segment 2 start         LUT segment 1 start | Comment<br>The sine wave look up table can be divided into up to<br>four segments using an individual step width control<br>entry <i>Wx</i> . The segment borders are selected by <i>X1</i> , <i>X2</i><br>and <i>X3</i> .<br>Segment 0 goes from 0 to <i>X1-1</i> .<br>Segment 1 goes from <i>X1</i> to <i>X2-1</i> .<br>Segment 2 goes from <i>X2</i> to <i>X3-1</i> .<br>Segment 3 goes from <i>X3</i> to 255.<br>For defined response the values shall satisfy:<br>0< <i>X1</i> < <i>X2</i> < <i>X3</i> |
| 10<br>9<br>8                                                                                                                                                                                                                               |                   |                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7                                                                                                                                                                                                                                          | W3                | LUT width select from                                                                        | Width control bit coding W0W3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6                                                                                                                                                                                                                                          |                   | ofs(X3) to ofs255                                                                            | %00: MSLUT entry 0, 1 select: -1, +0                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5                                                                                                                                                                                                                                          | W2                | LUT width select from                                                                        | %01: MSLUT entry 0, 1 select: +0, +1                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4                                                                                                                                                                                                                                          |                   | ofs(X2) to ofs(X3-1)                                                                         | %10: MSLUT entry 0, 1 select: +1, +2                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3<br>2                                                                                                                                                                                                                                     | W1                | LUT width select from<br>ofs(X1) to ofs(X2-1)                                                | %11: MSLUT entry 0, 1 select: +2, +3                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1<br>0                                                                                                                                                                                                                                     | WO                | LUT width select from<br>ofs00 to ofs(X1-1)                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                                                                                                                                                            |                   |                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

## 6.5.1 MSLUTSEL - Look up Table Segmentation Definition

S C E LE C T R O N I C

www.trinamic.com

## 6.5.2 CHOPCONF – Chopper Configuration

| automatically becomes doubled during high velocity operation in order to avoid doubling of the chopper frequency.         18       vhighfs       high velocity fullstep selection       This bit enables switching to fullstep, when VHIGH is exceeded. Switching takes place only at 45° position. The fullstep target current uses the current value from the microstep table at the 45° position.         17       -       reserved       reserved, set to 0         16       tbl1       TBL       %00 %11:         15       tbl0       blank time select       Set comparator blank time to 16, 24, 36 or 54 clocks Hint: %01 or %10 is recommended for most applications         14       chm       chopper mode       0       Standard mode (SpreadCycle)         13       -       reserved       Reserved, set to 0       1         13       -       reserved       set to 0       1         12       disfdcc       fast decay mode       chm=1:       disfdcc=1 disables current comparator usage for termination of the fast decay cycle         11       fd3       TFD [3]       chm=1:       disfdcay cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>0</b> x6C | <b>0x6C:</b> CHOPCONF – CHOPPER CONFIGURATION |                         |                                                          |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----------------------------------------------|-------------------------|----------------------------------------------------------|--|
| protection disable         1: Short to VS protection is disabled           30         diss2g         short to GND         0: Short to GND protection is on           28         interpolation to 256         1: Short to GND protection is disabled           28         interpolation to 256         1: That actual microstep resolution (MRES) becomes extrapolated to 256 microsteps for smoothest motor operation (useful for STEP/DIR operation, only)           27         mres3         MRES         \$40000;           26         mres1         \$40000;         Native 256 microsteps for smoothest motor operation (useful for STEP/DIR operation, only)           24         mres0         \$40000;         Native 256 microstep setting. Normally use this setting with the internal motion controller.           24         mres0         \$40000;         Native 256 microstep setting. Normally use this setting with the internal motion controller.           24         mres0         \$40000;         \$40000;         \$26, 4, 32, 16, 8, 4, 2, FULLSTEP           24         mres0         TPFD         Pasive fast decay time setting controls duration of the resolution gives the number of microstep neosinos which resolution.           25         tpfd3         TPFD         Pasive fast decay time setting controls duration of the fast decay phase inserted after bridge polarity change Note: 20000;           26         tpfd4         high velocity chopert mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Bit          | Name                                          | Function                | Comment                                                  |  |
| protection disable         1: Short to VS protection is disabled           30         diss2g         short to GND         0: Short to GND protection is on           28         interpolation to 256         1: Short to GND protection is disabled           28         interpolation to 256         1: That actual microstep resolution (MRES) becomes extrapolated to 256 microsteps for smoothest motor operation (useful for STEP/DIR operation, only)           27         mres3         MRES         \$40000;           26         mres1         \$40000;         Native 256 microsteps for smoothest motor operation (useful for STEP/DIR operation, only)           24         mres0         \$40000;         Native 256 microstep setting. Normally use this setting with the internal motion controller.           24         mres0         \$40000;         Native 256 microstep setting. Normally use this setting with the internal motion controller.           24         mres0         \$40000;         \$40000;         \$26, 4, 32, 16, 8, 4, 2, FULLSTEP           24         mres0         TPFD         Pasive fast decay time setting controls duration of the resolution gives the number of microstep neosinos which resolution.           25         tpfd3         TPFD         Pasive fast decay time setting controls duration of the fast decay phase inserted after bridge polarity change Note: 20000;           26         tpfd4         high velocity chopert mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |              |                                               |                         |                                                          |  |
| 30       diss2g       short to GND       0: Short to GND protection is on         29       dedge       enable double edge       1: Short to GND protection is disabled         28       intpol       interpolation to 256         microsteps       pertain of the studial microstep resolution (MRES) becomes         27       mres3       MRES         26       mres2       micro step resolution         27       mres3       MRES         26       mres2       micro step resolution         27       mres0       Native 256 microstep setting, Normally use this setting with the internal motion controller.         26       mres1       TFFD         27       mres2       passive fast decay time         28       tpfd3       TPFD         29       vhigh/s       passive fast decay time         20       tpfd4       passive fast decay time         20       tpfd4       passive fast decay time         20       tpfd4       passive fast decay time         21       tpdf1       passive fast decay time         22       tpfd4       passive fast decay time         23       tpfd4       TPFD         24       tpd4       passive fast decay time setting controls duration of th                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                                               |                         |                                                          |  |
| Protection disable         1: Short to GND protection is disabled           29         dedge         enable double edge<br>step pulses         1: Enable step impulse at each step edge to reduce step<br>frequency requirement.           28         intpol         interpolation to 256         1: The actual microstep resolution (MRES) becomes<br>extrapolated to 256 microsteps for smoothest motor<br>operation (useful for STEP/DIR operation, only)           27         mres3         MRES         %0000           26         mres2         micro step resolution         %0000:<br>Native 256 microstep, setting, Normally use this setting<br>with the internal motion controller.           26         mres0         %0000:<br>Native 256 microstep resolution esp. for STEP/DIR operation.<br>The resolution gives the number of microstep entries per<br>sine quarter wave.<br>The driver automatically uses microstep positions which<br>result in a symmetrical wave, when choosing a lower<br>microstep resolution.<br>step width=2*MRES [microsteps]           23         tpfd3         TPFD           24         tpfd3         TPFD           25         tpfd4         TPFD           26         tpfd4         TPFD           27         tpfd4         TPFD           28         tpfd3         TPFD           29         tpfd4         TPFD           20         tpfd4         Indf1           20         tpfd4         TPFD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 30           | diss2q                                        |                         |                                                          |  |
| 29       dedge       enable double edge       1: Enable step impulse at each step edge to reduce step frequency requirement.         28       intpol       interpolation to 256       1: The atrual microstep resolution (MRES) becomes extrapolated to 256 microsteps for smoothest motor operation (useful for STEP/DIR operation, only)         27       mres3       MRES       %0000:         26       mres0       Native 256 microstep, setting, Normally use this setting with the internal motion controller.         26       mres0       Native 256 microstep, setting, Normally use this setting with the internal motion controller.         26       mres0       Native 256 microstep, setting, Normally use this setting with the internal motion controller.         28       tpfd3       TPFD       Reduced microstep resolution est, for STEP/DIR operation.         23       tpfd3       TPFD       Reduced microstep resolution.       step width-2*MRES [microstep]         29       vhighfs       passive fast decay time       Passive fast decay time setting controls duration of the fast decay phase inserted after bridge polarity change         20       tpfd3       TPFD       Note: *1PFD       Note: *1PFD         20       tpfd4       passive fast decay time       This bit enables switching to chan-1 and fd-0, when VHIGH is exceeded. This way, a higher velocity can be achieved.         20       tpdfd       tpdd       Noid:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |              | 5                                             | protection disable      |                                                          |  |
| 28       intpol       interpolation to 256         microsteps       1: The actual microstep resolution (MRES) becomes extrapolated to 256 microsteps for smoothest motor operation (useful for STEP/DIR operation, only)         27       mres3       MRES         26       mres1       microstep resolution         27       mres1       Native 256 microstep setting, Normally use this setting         26       mres0       128, 64, 32, 16, 8, 4, 2, FULISTEP         24       mres0       128, 64, 32, 16, 8, 4, 2, FULISTEP         24       mres0       128, 64, 32, 16, 8, 4, 2, FULISTEP         26       guarter wave.       The driver automatically uses microstep positions which result in a symmetrical wave, when choosing a lower microstep resolution.         23       tpfd3       TPFD         24       passive fast decay time       The driver automatically uses microstep positions which result in a symmetrical wave, when choosing a lower microstep resolution.         23       tpfd3       TPFD         24       passive fast decay time       The driver automatically uses microstep positions which result in a symmetrical wave, when choosing a lower microstep resolution.         24       tpdf3       TPFD         25       tpfd2       passive fast decay time         26       tpfd3       TPFD         27       tpfd4<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 29           | dedge                                         | enable double edge      |                                                          |  |
| microsteps         extrapolated to 256 microsteps for smoothest motor<br>operation (useful for STEP/DIR operation, only)           27         mres3         MRE5           26         mres1         "micro step resolution"         "with the internal motion controller.           24         mres0         "storostep setting, Normally use this setting<br>with the internal motion controller.           24         mres0         "storostep resolution csp. for STEP/DIR operation.<br>The resolution gives the number of microstep entries per<br>sine quarter wave.           23         tpfd3         TPFD           24         mode         TPFD allows dampening of motor mid-range resonances.<br>The driver automatically uses microstep positions which<br>result in a symmetrical wave, when choosing a lower<br>microstep resolution.<br>step width=2 <sup>2</sup> MRE5 [microsteps]           23         tpfd3         TPFD<br>passive fast decay time<br>setting controls duration of the<br>fast decay phase inserted after bridge polarity change<br>Nace 128 <sup>h</sup> TPFD           20         tpfd1         .         This bit enables switching to chm-1 and fd-0, when VHIGH<br>is exceeded. This way, a higher velocity can be achieved.<br>Can be combined with <i>wighfs</i> -1 If set, the TOFF setting<br>automatically becomes doubled during high velocity<br>operation in order to avoid doubling of the chopper<br>frequency.           18         high selecting         "wood = %11"           17         reserved         reserved           18         tbil         TBil           1                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              | -                                             | step pulses             | frequency requirement.                                   |  |
| 27       mres3       MRES         26       mres0       micro step resolution         24       mres0       witw 256 microstep setting. Normally use this setting         24       mres0       witw 256 microstep setting. Normally use this setting         24       mres0       with the internal motion controller.         24       mres0       with the internal motion controller.         24       mres0       resolution gives the number of microstep entries per sine quarter wave.         25       microstep resolution.       step width-2*MRES [microstep]         26       tp/d2       passive fast decay time       Passive fast decay time setting controls duration of the fast decay hase inserted after bridge polarity change         20       tp/d0       midplf       high velocity chopper       This bit enables switching to chm=1 and fd=0, when VHIGH is exceeded. This way, a higher velocity can be achieved. Can be combined with vhighfs=1. If set, the TOFF setting automatically becomes doubled during high velocity operation in order to avoid doubling of the chopper frequency.         18       whighfs       high velocity fullstep seceeded. Switching to fullstep, when VHIGH is seceeded. This way, a higher velocity can be achieved. Can be combined with vhighfs=1. If set, the TOFF setting automatically becomes doubled during high velocity fullstep seceeded. This way, a higher velocity can be achieved. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 28           | intpol                                        | interpolation to 256    | •                                                        |  |
| 26       mres2         27       mres1         24       mres0         25       mres0         26       mres0         27       mres0         28       64, 32, 16, 8, 4, 2, FULLSTEP         Reduced microstep resolution esp. for STEP/DIR operation.<br>The resolution gives the number of microstep entries per<br>sine quarter wave.         23       tpfd3         24       tpfd1         25       tpfd2         26       tpfd1         27       tpfd1         28       tpfd1         29       tpfd1         20       tpfd1         20       tpfd1         20       tpfd0         20       tpfd0         20       tpfd0         20       tpfd0         20       tpfd0         20       tpfd0         21       tpfd1         22       tpfd1         23       tpfd1         24       mode         25       tpfd1         26       tpfd1         27       tpfd2         28       vhighfs-         ingh velocity chopper       mode         36 <td></td> <td></td> <td></td> <td>operation (useful for STEP/DIR operation, only)</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |              |                                               |                         | operation (useful for STEP/DIR operation, only)          |  |
| 25       mres1         24       mres0         25       mres0         26       mres0         27       with the internal motion controller.         %0001 _ %100:       %2001 _ %100:         128, 64, 32, 16, 8, 4, 2, FULLSTEP         Reduced microstep resolution esp. for STEP/DIR operation.         The resolution gives the number of microstep entries per sine quarter wave.         The driver automatically uses microstep positions which result in a symmetrical wave, when choosing a lower microstep resolution.         23       tp/d2         24       tp/d1         25       tp/d2         26       tp/d1         27       tp/d1         28       tp/d2         29       tp/d1         20       tp/d0         7000:       Disable %0001 _ %111: 1 _ 15         19       vhighr/s         high velocity chopper mode       Sexceedd. This way, a higher velocity can be achieved.         Can be combined with vhighrs1.       first, the TOFF setting automatically becomes doubled during high velocity outper frequency.         18       vhighr/s       high velocity fullstep selection         17       reserved       reserved, set to 0         18       vhighr/s       high velocity fullstep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 27           | mres3                                         | MRES                    | %0000:                                                   |  |
| 24       mres0         24       mres0         24       mres0         25       tp/d3         23       tp/d3         24       tp/d3         25       tp/d3         26       tp/d3         27       tp/d3         28       tp/d1         29       tp/d1         20       tp/d1         21       tp/d2         22       tp/d1         23       tp/d1         24       mode         25       tp/d2         26       tp/d2         27       tp/d2      <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 26           | mres2                                         | micro step resolution   | Native 256 microstep setting. Normally use this setting  |  |
| 128, 64, 32, 16, 8, 4, 2, FULLSTEP         Reduced microstep resolution sp. for STEP/DIR operation.<br>The resolution gives the number of microstep positions which<br>result in a symmetrical wave, when choosing a lower<br>microstep resolution.<br>step width=2*MRES [microsteps]         23       tpfd3         24       tpfd1         25       tpfd1         26       tpfd1         27       tpfd1         28       tpfd1         29       tpfd1         20       tpfd0         21       tpfd1         22       tpfd1         23       tpfd1         24       tpfd1         25       tpfd2         26       tpfd1         27       refs         28       tpfd1         29       whighrsh         high velocity coloper       This bit enables switching to chm=1 and fd=0, when VHIGH         38       vhighrs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 25           | mres1                                         |                         | with the internal motion controller.                     |  |
| Reduced microstep resolution esp. for STEP/DIR operation.<br>The resolution gives the number of microstep entries per<br>sine quarter wave.<br>The driver automatically uses microstep positions which<br>result in a symmetrical wave, when choosing a lower<br>microstep resolution.<br>step width=2*MRES [microsteps]23tpfd324tpfd2<br>passive fast decay time<br>to tpfd020tpfd120tpfd020tpfd020tpfd020tpfd020tpfd020tpfd020tpfd020tpfd021tpfd122tpfd023tpfd024tpfd125tpfd026tpfd027tpfd028vhighrsh19whighrshhigh velocity chopper<br>mode29tpfd120tpfd120tpfd020tpfd020tpfd020tpfd120tpfd120tpfd021tpfd222tpfd123tpfd224tpfd225tpfd026tpfd227tpfd228tpfd229tpfd220tpfd020tpfd120tpfd220tpfd221tpfd222tpfd223tpfd224tpfd225tpfd226tpfd2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 24           | mres0                                         |                         | %0001 %1000:                                             |  |
| 23       tpfd3       TPFD         22       tpfd2       passive fast decay time       TPFD allows dampening of motor mid-range resonances.         22       tpfd1       passive fast decay time       TPFD allows dampening of motor mid-range resonances.         20       tpfd1       passive fast decay time       Passive fast decay time ast time setting controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of the fast decay time setting to controls duration of terminated when the negative nominal current is reached. Fast decay is after on time.         17       -       reserved       Reserved, set to 0         16       tbil       b                                                                                                                                                                                                                                                                                          |              |                                               |                         | 128, 64, 32, 16, 8, 4, 2, FULLSTEP                       |  |
| sine quarter wave.       The driver automatically uses microstep positions which result in a symmetrical wave, when choosing a lower microstep resolution.         23       tpfd3       TPFD         22       tpfd2       passive fast decay time       Passive fast decay time fast decay time setting controls duration of the fast decay phase inserted after bridge polarity change Nex= 128*TPFD         20       tpfd0       %00001: Disable %0001: withit 1 15         19       whighchm       high velocity chopper mode         18       whighfs       high velocity fullstep selection         17       reserved       reserved.         18       vhighfs       high velocity fullstep selection         14       chm       chopper mode       %00 - %11:         15       tbl0       blank time select       %00 - %11:         14       chm       chopper mode       0       Standard mode (Spread/Ycle)         13       -       reserved, set to 0       1       Constant off time with fast decay time.         13       -       reserved       Reserved, set to 0       1         14       fast decay mode       chm=1:       disfdcc       fast decay mode         13       -       reserved, set to 0       1       Constant off time with fast decay time.         14 <td></td> <td></td> <td></td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                                               |                         |                                                          |  |
| 23       tpfd3       TPFD         22       tpfd2       passive fast decay time       Fast decay time setting controls duration of the chopper frequency.         19       vhighfs       high velocity chopper mode       This bit enables switching to chm-1 and fd-0, when VHIGH is exceeded. This way, a higher velocity can be achieved. Can be combined with vhighfs-1. If set, the TOFF setting automatically becomes doubled doubling of the chopper frequency.         18       vhighfs       high velocity fullstep select       This bit enables switching to fullstep, when VHIGH is exceeded. Switching takes place only at 45° position. The fullstep target current uses the current value from the microstep table at the 45° position.         17       -       reserved       reserved, set to 0       Standard mode (SpreadCycle)                                                                                                                                                                                                                                                                                  |              |                                               |                         |                                                          |  |
| 23       tpfd3       TPFD         22       tpfd2       passive fast decay time       TPFD allows dampening of motor mid-range resonances.         21       tpdf1       passive fast decay time       Passive fast decay time setting controls duration of the fast decay phase inserted after bridge polarity change N <sub>Cut</sub> = 128*TPFD         20       tpfd0       whighchm       high velocity chopper mode       This bit enables switching to chm=1 and fd=0, when VHIGH is exceeded. This way, a higher velocity can be achieved. Can be combined with vhighfs=1. If set, the TOFF setting automatically becomes doubled during high velocity operation in order to avoid doubling of the chopper frequency.         18       vhighfs       high velocity fullstep selection       This bit enables switching to fullstep, when VHIGH is exceeded. Switching takes place only at 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position.         17       -       reserved       reserved, set to 0         16       tbil       TBl       %00 %11:         15       tbl0       blank time select       1         14       chm       chopper mode       0       Standard mode (SpreadCycle)         13       -       reserved       Reserved, set to 0       1         12       disfdcc       fast decay mode       chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                                               |                         |                                                          |  |
| Image: second |              |                                               |                         |                                                          |  |
| step width=2*MRES [microsteps]23tpfd3TPFD22tpfd2passive fast decay time20tpfd020tpfd020tpfd019vhighchmhigh velocity chopper<br>modemode18vhighfs18vhighfs17-18vhighfs19thigh velocity fullstep<br>selection18vhighfs19thigh velocity fullstep<br>selection18vhighfs19thigh velocity fullstep<br>selection18vhighfs19thigh velocity fullstep<br>selection18vhighfs19thigh velocity fullstep<br>selection10tbil11tbil12tbil13-14chm15tbil013-13-13-13-14fast decay mode13-14fast decay mode14fast decay mode15tbil016tbil217fast decay mode18thigh chopper mode13-14thm15tbil016tbil117-18tbil219tbil319tbil419tbil419tbil519tbil619tbil719                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |              |                                               |                         |                                                          |  |
| 23       tpfd3       TPFD         22       tpfd2       passive fast decay time       Passive fast decay time setting controls duration of the fast decay phase inserted after bridge polarity change Note: 128*TPFD %0000: Disable %0001 %1111: 1 15         19       vhighchm       high velocity chopper mode       This bit enables switching to chm=1 and fd=0, when VHIGH is exceeded. This way, a higher velocity can be achieved. Can be combined with vhighfs=1. If set, the TOFF setting automatically becomes doubled during high velocity operation in order to avoid doubling of the chopper frequency.         18       vhighfs       high velocity fullstep selection       This bit enables switching to fullstep, when VHIGH is exceeded. Switching takes place only at 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position.         14       chm       chopper mode       0       Standard mode (SpreadCycle)       1       Constan                                                                                                                                                                                                                                                                                 |              |                                               |                         |                                                          |  |
| 22       tpfd2       passive fast decay time       Passive fast decay time setting controls duration of the fast decay phase inserted after bridge polarity change Ncree 128*TPFD %00001. Disable %0001 %1111: 1 15         19       vhighchm       high velocity chopper mode       This bit enables switching to chm=1 and fd=0, when VHIGH is exceeded. This way, a higher velocity can be achieved. Can be combined with vhighfs=1. If set, the TOFF setting automatically becomes doubled during high velocity operation in order to avoid doubling of the chopper frequency.         18       vhighfs       high velocity fullstep selection       This bit enables switching to fullstep, when VHIGH is exceeded. Switching takes place only at 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The fullstep target current uses the current value from the microstep table at the 45° position. The full time select         14       chm       chopper mode       0       Standard mode (SpreadCycle)       1         13       reserved       fast decay mode       chm=1:       disfdcc=1 disables current comparator usage for termination of the fast decay cycle         11       fd3 <td>23</td> <td>tofd3</td> <td>TPED</td> <td></td>                                                                                                                                                                                                                                                                              | 23           | tofd3                                         | TPED                    |                                                          |  |
| 21       tpf1         20       tpfd0         20       tpfd1         21       tpfd1         218       tpfd1         218       tpfd1         219       tpfd1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |                                               |                         |                                                          |  |
| 20       tpfd0       Nctx= 128*TPFD         19       vhighchm       high velocity chopper mode       This bit enables switching to chm=1 and fd=0, when VHIGH is exceeded. This way, a higher velocity can be achieved. Can be combined with vhighfs=1. If set, the 70FF setting automatically becomes doubled during high velocity operation in order to avoid doubling of the chopper frequency.         18       vhighfs       high velocity fullstep selection       This bit enables switching to fullstep, when VHIGH is exceeded. Switching takes place only at 45° position.         17       -       reserved       reserved, set to 0         16       tbl1       TBL       %00 %11:         15       tbl0       blank time select       %00 %10 is recommended for most applications         14       chm       chopper mode       0       Standard mode (Spread(ycle)         13       -       reserved       Reserved, set to 0       1         13       -       reserved       Reserved, set to 0       1         12       disfdcc       fast decay mode       chm=1:       disfdcc=1 disables current comparator usage for termination of the fast decay cycle         11       fd3       TFD [3]       chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              |                                               | passive last decay time |                                                          |  |
| 19       vhighchm       high velocity chopper mode       This bit enables switching to chm=1 and fd=0, when VHIGH is exceeded. This way, a higher velocity can be achieved. Can be combined with vhighfs=1. If set, the TOFF setting automatically becomes doubled during high velocity operation in order to avoid doubling of the chopper frequency.         18       vhighfs       high velocity fullstep selection       This bit enables switching to fullstep, when VHIGH is exceeded. Switching takes place only at 45° position.         17       -       reserved       reserved, set to 0         16       tbl1       TBL       %00 %11:         15       tbl0       blank time select       %00 %11:         14       chm       chopper mode       0       Standard mode (SpreadCycle)         13       -       reserved       Reserved, set to 0       1         13       -       reserved       Reserved, set to 0       1         12       disfdcc       fast decay mode       chm=1:       disfdcc=1 disables current comparator usage for termination of the fast decay cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              |                                               |                         |                                                          |  |
| 19vhighchm<br>modehigh velocity chopper<br>modeThis bit enables switching to chm=1 and fd=0, when VHIGH<br>is exceeded. This way, a higher velocity can be achieved.<br>Can be combined with vhighfs=1. If set, the TOFF setting<br>automatically becomes doubled during high velocity<br>operation in order to avoid doubling of the chopper<br>frequency.18vhighfshigh velocity fullstep<br>selectionThis bit enables switching to fullstep, when VHIGH is<br>exceeded. Switching takes place only at 45° position.<br>The fullstep target current uses the current value from<br>the microstep table at the 45° position.17-reservedreserved, set to 016tbl1TBL<br>blank time select%00 %11:<br>Set comparator blank time to 16, 24, 36 or 54 clocks<br>Hint: %01 or %10 is recommended for most applications14chmchopper mode0Standard mode (SpreadCycle)13-reserved<br>fast decay modeReserved, set to 012disfdccfast decay modechm=1:<br>disfdcc=1 disables current comparator usage for termi-<br>nation of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 20           | ipjuo                                         |                         |                                                          |  |
| 19vhighchmhigh velocity chopper<br>modeThis bit enables switching to chm=1 and fd=0, when VHIGH<br>is exceeded. This way, a higher velocity can be achieved.<br>Can be combined with vhighfs=1. If set, the TOFF setting<br>automatically becomes doubled during high velocity<br>operation in order to avoid doubling of the chopper<br>frequency.18vhighfshigh velocity fullstep<br>selectionThis bit enables switching to fullstep, when VHIGH is<br>exceeded. Switching to fullstep, when VHIGH is<br>exceeded. Switching takes place only at 45° position.<br>The fullstep target current uses the current value from<br>the microstep table at the 45° position.17-reservedreserved, set to 016tbl1TBL<br>blank time select%00 %11;<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              |                                               |                         |                                                          |  |
| Imodeis exceeded. This way, a higher velocity can be achieved.<br>Can be combined with vhighfs=1. If set, the TOFF setting<br>automatically becomes doubled during high velocity<br>operation in order to avoid doubling of the chopper<br>frequency.18vhighfshigh velocity fullstep<br>selectionThis bit enables switching to fullstep, when VHIGH is<br>exceeded. Switching takes place only at 45° position.17-reservedreserved, set to 016tbl1TBL<br>blank time select%00 %11:<br>Set comparator blank time to 16, 24, 36 or 54 clocks<br>Hint: %01 or %10 is recommended for most applications14chmchopper mode0Standard mode (SpreadCycle)13-reservedReserved, set to 012disfdccfast decay modechm=1:11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 19           | vhiahchm                                      | high velocity chopper   |                                                          |  |
| Can be combined with vhighfs=1. If set, the TOFF setting<br>automatically becomes doubled during high velocity<br>operation in order to avoid doubling of the chopper<br>frequency.18vhighfshigh velocity fullstep<br>selectionThis bit enables switching to fullstep, when VHIGH is<br>exceeded. Switching takes place only at 45° position.<br>The fullstep target current uses the current value from<br>the microstep table at the 45° position.17-reservedreserved, set to 016tbl1TBL<br>blank time select%00 %11:<br>Set comparator blank time to 16, 24, 36 or 54 clocks<br>Hint: %01 or %10 is recommended for most applications14chmchopper mode0Standard mode (SpreadCycle)13-reservedReserved, set to 013-reservedReserved, set to 012disfdccfast decay modechm=1:<br>disfdcc=1 disables current comparator usage for termination of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |              | July                                          |                         |                                                          |  |
| 18vhighfshigh velocity fullstep<br>selectionThis bit enables switching to fullstep, when VHIGH is<br>exceeded. Switching takes place only at 45° position.<br>The fullstep target current uses the current value from<br>the microstep table at the 45° position.<br>The fullstep target current uses the current value from<br>the microstep table at the 45° position.17-reservedreserved, set to 016tbl1TBL<br>blank time select%00 %11:<br>Set comparator blank time to 16, 24, 36 or 54 clocks<br>Hint: %01 or %10 is recommended for most applications14chmchopper mode0Standard mode (SpreadCycle)13-reservedReserved, set to 012disfdccfast decay modechm=1:<br>disfdccchm=1:<br>disfdcc-1 disables current comparator usage for termination of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |                                               |                         | Can be combined with vhighfs=1. If set, the TOFF setting |  |
| 18vhighfshigh velocity fullstep<br>selectionThis bit enables switching to fullstep, when VHIGH is<br>exceeded. Switching takes place only at 45° position.<br>The fullstep target current uses the current value from<br>the microstep table at the 45° position.17-reservedreserved, set to 016tbl1TBL%00 %11:<br>Set comparator blank time to 16, 24, 36 or 54 clocks<br>Hint: %01 or %10 is recommended for most applications14chmchopper mode0Standard mode (SpreadCycle)13-reservedReserved, set to 012disfdccfast decay modechm=1:<br>disfdcc=1 disables current comparator usage for termination of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |              |                                               |                         |                                                          |  |
| 18       vhighfs       high velocity fullstep<br>selection       This bit enables switching to fullstep, when VHIGH is<br>exceeded. Switching takes place only at 45° position.<br>The fullstep target current uses the current value from<br>the microstep table at the 45° position.         17       -       reserved       reserved, set to 0         16       tbl1       TBL       %00 %11:         15       tbl0       blank time select       Set comparator blank time to 16, 24, 36 or 54 clocks<br>Hint: %01 or %10 is recommended for most applications         14       chm       chopper mode       0       Standard mode (SpreadCycle)         1       Constant off time with fast decay time.<br>Fast decay time is also terminated when the<br>negative nominal current is reached. Fast decay is<br>after on time.         13       -       reserved       Reserved, set to 0         12       disfdcc       fast decay mode       chm=1:<br>disfdcc=1 disables current comparator usage for termi-<br>nation of the fast decay cycle         11       fd3       TFD [3]       chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |              |                                               |                         |                                                          |  |
| selection       exceeded. Switching takes place only at 45° position.<br>The fullstep target current uses the current value from the microstep table at the 45° position.         17       reserved       reserved, set to 0         16       tbl1       TBL         15       tbl0       blank time select         14       chm       chopper mode         13       -       reserved         13       -       reserved         13       -       reserved         14       disfdcc       fast decay mode         chm=1:       disfdcc=1       disables current comparator usage for termination of the fast decay cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 10           |                                               |                         |                                                          |  |
| 17-reservedreserved, set to 016tbl1TBL%00 %11:15tbl0blank time select%00 %11:14chmchopper mode0Standard mode (SpreadCycle)13-reservedReserved, set to 013-reservedReserved, set to 012disfdccfast decay modechm=1:11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 18           | vhighfs                                       |                         |                                                          |  |
| 17-reservedreserved, set to 016tbl1TBL%00 %11:15tbl0blank time selectSet comparator blank time to 16, 24, 36 or 54 clocks<br>Hint: %01 or %10 is recommended for most applications14chmchopper mode013-reserved13-reserved12disfdccfast decay mode11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |              |                                               | selection               |                                                          |  |
| 17-reservedreserved, set to 016tbl1TBL%00 %11:15tbl0blank time selectSet comparator blank time to 16, 24, 36 or 54 clocks<br>Hint: %01 or %10 is recommended for most applications14chmchopper mode0Standard mode (SpreadCycle)14chmchopper mode0Standard mode (SpreadCycle)13-reservedReserved, set to 013-reservedReserved, set to 012disfdccfast decay modechm=1:<br>disfdcc=1 disables current comparator usage for termination of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              |                                               |                         |                                                          |  |
| 16tbl1TBL<br>blank time select%00 %11:<br>Set comparator blank time to 16, 24, 36 or 54 clocks<br>Hint: %01 or %10 is recommended for most applications14chmchopper mode0Standard mode (SpreadCycle)14chmchopper mode0Standard mode (SpreadCycle)14chmchopper mode0Standard mode (SpreadCycle)13-reservedReserved, set to 012disfdccfast decay modechm=1:<br>disfdcc=1 disables current comparator usage for termination of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 17           |                                               | received                |                                                          |  |
| 15tbl0blank time selectSet comparator blank time to 16, 24, 36 or 54 clocks<br>Hint: %01 or %10 is recommended for most applications14chmchopper mode0Standard mode (SpreadCycle)14chmchopper mode0Standard mode (SpreadCycle)1Constant off time with fast decay time.<br>Fast decay time is also terminated when the<br>negative nominal current is reached. Fast decay is<br>after on time.13-reservedReserved, set to 012disfdccfast decay modechm=1:<br>disfdcc=1 disables current comparator usage for termi-<br>nation of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |              | thi                                           |                         |                                                          |  |
| Hint: %01 or %10 is recommended for most applications14chmchopper mode0Standard mode (SpreadCycle)1Constant off time with fast decay time.<br>Fast decay time is also terminated when the<br>negative nominal current is reached. Fast decay is<br>after on time.13-reservedReserved, set to 012disfdccfast decay modechm=1:<br>disfdcc=1 disables current comparator usage for termi-<br>nation of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              |                                               |                         |                                                          |  |
| 14chmchopper mode0Standard mode (SpreadCycle)1Constant off time with fast decay time.<br>Fast decay time is also terminated when the<br>negative nominal current is reached. Fast decay is<br>after on time.13-reservedReserved, set to 012disfdccfast decay modechm=1:<br>disfdcc=1 disables current comparator usage for termi-<br>nation of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 11           | LDIO                                          |                         |                                                          |  |
| 1Constant off time with fast decay time.<br>Fast decay time is also terminated when the<br>negative nominal current is reached. Fast decay is<br>after on time.13-reserved13-Reserved, set to 012disfdccfast decay mode11fd3TFD [3]chm=1:<br>chm=1:chm=1:chm=1:<br>nation of the fast decay cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 14           | chm                                           | chopper mode            |                                                          |  |
| Fast decay time is also terminated when the<br>negative nominal current is reached. Fast decay is<br>after on time.13-reservedReserved, set to 012disfdccfast decay modechm=1:<br>disfdcc=1 disables current comparator usage for termi-<br>nation of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | - •          |                                               |                         |                                                          |  |
| 13       -       reserved       Reserved, set to 0         12       disfdcc       fast decay mode       chm=1:<br>disfdcc=1 disables current comparator usage for termi-<br>nation of the fast decay cycle         11       fd3       TFD [3]       chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              |                                               |                         |                                                          |  |
| 13     -     reserved     Reserved, set to 0       12     disfdcc     fast decay mode     chm=1:<br>disfdcc=1 disables current comparator usage for termi-<br>nation of the fast decay cycle       11     fd3     TFD [3]     chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |              |                                               |                         |                                                          |  |
| 13       -       reserved       Reserved, set to 0         12       disfdcc       fast decay mode       chm=1:<br>disfdcc=1 disables current comparator usage for termi-<br>nation of the fast decay cycle         11       fd3       TFD [3]       chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              |                                               |                         |                                                          |  |
| 12disfdccfast decay modechm=1:<br>disfdcc=1 disables current comparator usage for termi-<br>nation of the fast decay cycle11fd3TFD [3]chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 13           | -                                             | reserved                |                                                          |  |
| disfdcc=1 disables current comparator usage for termination of the fast decay cycle       11     fd3       TFD [3]     chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              | disfdcc                                       |                         |                                                          |  |
| Image: nation of the fast decay cycle       11     fd3       TFD [3]     chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              | -                                             |                         | disfdcc=1 disables current comparator usage for termi-   |  |
| 11         fd3         TFD [3]         chm=1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              |                                               |                         |                                                          |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 11           | fd3                                           | TFD [3]                 |                                                          |  |
| MSB of fast decay time setting <i>IFD</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |              |                                               |                         | MSB of fast decay time setting TFD                       |  |

www.trinamic.com

| 0x60 | <b>0x6C:</b> CHOPCONF – CHOPPER CONFIGURATION |                         |                                            |                                                            |  |
|------|-----------------------------------------------|-------------------------|--------------------------------------------|------------------------------------------------------------|--|
| Bit  | Name                                          | Function                | Comment                                    |                                                            |  |
| 10   | hend3                                         | HEND                    | chm=0                                      | %0000 %1111:                                               |  |
| 9    | hend2                                         | hysteresis low value    |                                            | Hysteresis is -3, -2, -1, 0, 1,, 12                        |  |
| 8    | hend1                                         | OFFSET                  |                                            | (1/512 of this setting adds to current setting)            |  |
| 7    | hend0                                         | sine wave offset        |                                            | This is the hysteresis value which becomes                 |  |
|      |                                               |                         |                                            | used for the hysteresis chopper.                           |  |
|      |                                               |                         | chm=1                                      | %0000 %1111:                                               |  |
|      |                                               |                         |                                            | Offset is -3, -2, -1, 0, 1,, 12                            |  |
|      |                                               |                         |                                            | This is the sine wave offset and 1/512 of the              |  |
|      |                                               |                         |                                            | value becomes added to the absolute value                  |  |
|      |                                               |                         |                                            | of each sine wave entry.                                   |  |
| 6    | hstrt2                                        | HSTRT                   | chm=0                                      | %000 %111:                                                 |  |
| 5    | hstrt1                                        | hysteresis start value  |                                            | Add 1, 2,, 8 to hysteresis low value HEND                  |  |
| 4    | hstrt0                                        | added to HEND           |                                            | (1/512 of this setting adds to current setting)            |  |
|      |                                               |                         | Attention: Effective HEND+HSTRT ≤ 16.      |                                                            |  |
|      |                                               |                         | Hint: Hysteresis decrement is done each 16 |                                                            |  |
|      |                                               |                         |                                            | clocks                                                     |  |
|      |                                               | TFD [20]                | chm=1                                      | Fast decay time setting (MSB: fd3):                        |  |
|      |                                               | fast decay time setting |                                            | %0000 %1111:                                               |  |
|      |                                               |                         |                                            | Fast decay time setting TFD with                           |  |
|      |                                               |                         |                                            | N <sub>CLK</sub> = 32* <i>TFD</i> (%0000: slow decay only) |  |
| 3    | toff3                                         | TOFF off time           |                                            | etting controls duration of slow decay phase               |  |
| 2    | toff2                                         | and driver enable       | N <sub>CLK</sub> = 24 + 32*TOFF            |                                                            |  |
| 1    | toff1                                         |                         | %0000: Driver disable, all bridges off     |                                                            |  |
| 0    | toff0                                         |                         |                                            | - use on <mark>ly with TBL ≥ 2</mark>                      |  |
|      |                                               |                         | %0010 %                                    | %1111: 2 <u></u> 15                                        |  |



www.trinamic.com

## 6.5.3 COOLCONF – Smart Energy Control CoolStep and StallGuard2

| <b>0x6</b> | 0x6D: COOLCONF – SMART ENERGY CONTROL COOLSTEP AND STALLGUARD2 |                              |                                                                                                                                                                |  |  |
|------------|----------------------------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit        | Name                                                           | Function                     | Comment                                                                                                                                                        |  |  |
|            | -                                                              | reserved                     | set to 0                                                                                                                                                       |  |  |
| 24         | sfilt                                                          | StallGuard2 filter<br>enable | 0 Standard mode, high time resolution for<br>StallGuard2                                                                                                       |  |  |
|            |                                                                |                              | 1 Filtered mode, StallGuard2 signal updated for each<br>four fullsteps (resp. six fullsteps for 3 phase motor)<br>only to compensate for motor pole tolerances |  |  |
| 23         | -                                                              | reserved                     | set to 0                                                                                                                                                       |  |  |
| 22         | sgt6                                                           | StallGuard2 threshold        | This signed value controls StallGuard2 level for stall                                                                                                         |  |  |
| 21         | sgt5                                                           | value                        | output and sets the optimum measurement range for                                                                                                              |  |  |
| 20         | sgt4                                                           |                              | readout. A lower value gives a higher sensitivity. Zero is                                                                                                     |  |  |
| 19         | sgt3                                                           |                              | the starting value working with most motors.                                                                                                                   |  |  |
| 18         | sgt2                                                           |                              | -64 to +63: A higher value makes StallGuard2 less                                                                                                              |  |  |
| 17         | sgt1                                                           |                              | sensitive and requires more torque to                                                                                                                          |  |  |
| 16         | sgt0                                                           |                              | indicate a stall.                                                                                                                                              |  |  |
| 15         | seimin                                                         | minimum current for          | 0: 1/2 of current setting (IRUN)                                                                                                                               |  |  |
|            |                                                                | smart current control        | 1: 1/4 of current setting (IRUN)                                                                                                                               |  |  |
| 14         | sedn1                                                          | current down step            | %00: For each 32 StallGuard2 values decrease by one                                                                                                            |  |  |
| 13         | sedn0                                                          | speed                        | %01: For each 8 StallGuard2 values decrease by one                                                                                                             |  |  |
|            |                                                                |                              | %10: For each 2 StallGuard2 values decrease by one                                                                                                             |  |  |
|            |                                                                |                              | %11: For each StallGuard2 value decrease by one                                                                                                                |  |  |
| 12         | -                                                              | reserved                     | set to 0                                                                                                                                                       |  |  |
| 11         | semax3                                                         | StallGuard2 hysteresis       | If the StallGuar <mark>d2 res</mark> ult is equal to or above                                                                                                  |  |  |
| 10         | semax2                                                         | value for smart current      | (SEMIN+SEMAX+1)*32, the motor current becomes                                                                                                                  |  |  |
| 9          | semax1                                                         | control                      | decreased to save energy.                                                                                                                                      |  |  |
| 8          | semax0                                                         |                              | %0000 %1111: 0 15                                                                                                                                              |  |  |
| 7          | -                                                              | reserved                     | set to 0                                                                                                                                                       |  |  |
| 6          | seup1                                                          | current up step width        | Current increment steps per measured StallGuard2 value                                                                                                         |  |  |
| 5          | seup0                                                          |                              | %00 %11: 1, 2, 4, 8                                                                                                                                            |  |  |
| 4          | -                                                              | reserved                     | set to 0                                                                                                                                                       |  |  |
| 3          | semin3                                                         | minimum StallGuard2          | If the StallGuard2 result falls below SEMIN*32, the motor                                                                                                      |  |  |
| 2          | semin2                                                         | value for smart current      | current becomes increased to reduce motor load angle.                                                                                                          |  |  |
| 1          | semin1                                                         | control and                  | %0000: smart current control CoolStep off                                                                                                                      |  |  |
| 0          | semin0                                                         | smart current enable         | %0001 %1111: 1 15                                                                                                                                              |  |  |
|            |                                                                |                              |                                                                                                                                                                |  |  |

ELECTRONIC

www.trinamic.com

## 6.5.4 PWMCONF - Voltage PWM Mode StealthChop

| 0x70                 | 0x70: PWMCONF – VOLTAGE MODE PWM STEALTHCHOP |                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|----------------------|----------------------------------------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit                  | Name                                         | Function                                                    | Comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 31<br>30<br>29<br>28 | PWM_LIM                                      | PWM automatic scale<br>amplitude limit when<br>switching on | Limit for <i>PWM_SCALE_AUTO</i> when switching back from<br>SpreadCycle to StealthChop. This value defines the upper<br>limit for bits 7 to 4 of the automatic current control<br>when switching back. It can be set to reduce the current<br>jerk during mode change back to StealthChop.<br>It does not limit <i>PWM_GRAD</i> or <i>PWM_GRAD_AUTO</i> offset.<br>(Default = 12)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 27<br>26<br>25<br>24 | PWM_REG                                      | Regulation loop<br>gradient                                 | User defined maximum PWM amplitude change per half<br>wave when using <i>pwm_autoscale</i> =1. (115):<br>1: 0.5 increments (slowest regulation)<br>2: 1 increment<br>3: 1.5 increments<br>4: 2 increments ( <i>Reset default</i> ))<br><br>8: 4 increments<br><br>15: 7.5 increments (fastest regulation)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 23                   | -                                            | reserved                                                    | set to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 22                   | -                                            | reserved                                                    | set to 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 21<br>20             | freewheel1<br>freewheel0                     | Allows different<br>standstill modes                        | Stand still option when motor current setting is zero<br>(I_HOLD=0).<br>%00: Normal operation<br>%01: Freewheeling<br>%10: Coil shorted using LS drivers<br>%11: Coil shorted using HS drivers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| 19                   | pwm_<br>autograd                             | PWM automatic<br>gradient adaptation                        | <ul> <li>Fixed value for PWM_GRAD<br/>(PWM_GRAD_AUTO = PWM_GRAD)</li> <li>Automatic tuning (only with pwm_autoscale=1)<br/>(Reset default)<br/>PWM_GRAD_AUTO is initialized with PWM_GRAD<br/>while pwm_autograd=0 and becomes optimized<br/>automatically during motion.<br/>Preconditions</li> <li>PWM_OFS_AUTO has been automatically<br/>initialized. This requires standstill at IRUN for<br/>&gt;130ms in order to a) detect standstill b) wait &gt;<br/>128 chopper cycles at IRUN and c) regulate<br/>PWM_OFS_AUTO so that<br/>-1 &lt; PWM_SCALE_AUTO &lt; 1</li> <li>Motor running and 1.5 * PWM_OFS_AUTO &lt;<br/>PWM_SCALE_SUM &lt; 4* PWM_OFS_AUTO and<br/>PWM_SCALE_SUM &lt; 255.</li> <li>Time required for tuning PWM_GRAD_AUTO<br/>About 8 fullsteps per change of +/-1.<br/>Also enables use of reduced chopper frequency for<br/>tuning PWM_OFS_AUTO.</li> </ul> |  |  |
| 18                   | pwm_<br>autoscale                            | PWM automatic<br>amplitude scaling                          | <ul> <li>0 User defined feed forward PWM amplitude. The current settings <i>IRUN</i> and <i>IHOLD</i> have no influence! The resulting PWM amplitude (limited to 0255) is: <i>PWM_OFS</i> * ((<i>CS_ACTUAL+1) / 32</i>) + <i>PWM_GRAD</i> * 256 <i>I TSTEP</i></li> <li>1 Enable automatic current control (<i>Reset default</i>)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |

www.trinamic.com

| 0x70 | : PWMCONF | - VOLTAGE MODE PWM S                 | TEALTHCHOP                                                                                                         |
|------|-----------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| Bit  | Name      | Function                             | Comment                                                                                                            |
| 17   | pwm_freq1 | PWM frequency                        | %00: f <sub>PWM</sub> =2/1024 f <sub>CLK</sub> (Reset default)                                                     |
| 16   | pwm_freq0 | selection                            | %01: f <sub>PWM</sub> =2/683 f <sub>CLK</sub>                                                                      |
|      |           |                                      | %10: f <sub>PWM</sub> =2/512 f <sub>CLK</sub>                                                                      |
|      |           |                                      | %11: f <sub>PWM</sub> =2/410 f <sub>CLK</sub>                                                                      |
| 15   | PWM_      | User defined amplitude               | Velocity dependent gradient for PWM amplitude:                                                                     |
| 14   | GRAD      | gradient                             | PWM_GRAD * 256 I TSTEP                                                                                             |
| 13   |           |                                      | This value is added to PWM_AMPL to compensate for                                                                  |
| 12   |           |                                      | the velocity-dependent motor back-EMF.                                                                             |
| 11   |           |                                      |                                                                                                                    |
| 10   |           |                                      | Use <i>PWM_GRAD</i> as initial value for automatic scaling to                                                      |
| 9    |           |                                      | speed up the automatic tuning process. To do this, set                                                             |
| 8    |           |                                      | PWM_GRAD to the determined, application specific value,                                                            |
|      |           |                                      | with <pre>pwm_autoscale=0. Only afterwards, set</pre>                                                              |
|      |           |                                      | <pre>pwm_autoscale=1. Enable StealthChop when finished.</pre>                                                      |
| 1    |           |                                      |                                                                                                                    |
|      |           |                                      | Hint:                                                                                                              |
|      |           |                                      | After initial tuning, the required initial value can be read                                                       |
|      |           |                                      | out from PWM_GRAD_AUTO.                                                                                            |
| 7    | PWM_      | User defined <mark>amplitud</mark> e | User defined PWM amplitude offset (0-255) related to full                                                          |
| 6    | OFS       | (offset)                             | motor current (CS_ACTUAL=31) in stand still.                                                                       |
| 5    |           |                                      | (Reset default=30)                                                                                                 |
| 4    |           |                                      |                                                                                                                    |
| 3    |           |                                      | Use PWM_OFS as initial value for automatic scaling to                                                              |
| 2    |           |                                      | speed up the aut <mark>omatic t</mark> uning process. To do this, set                                              |
| 1    |           |                                      | <i>PWM_OFS</i> to the determined, application specific value,                                                      |
| 0    |           |                                      | with <i>pwm_autoscale</i> =0. Only afterwards, set                                                                 |
|      |           |                                      | <pre>pwm_autoscale=1. Enable StealthChop when finished.</pre>                                                      |
|      |           |                                      |                                                                                                                    |
|      |           |                                      | <i>PWM_OFS</i> = 0 will disable scaling down motor current                                                         |
|      |           |                                      | below a motor specific lower measurement threshold.                                                                |
|      |           |                                      | This setting should only be used under certain                                                                     |
|      | 1         |                                      | conditions, i.e. when the power supply voltage can vary                                                            |
|      |           |                                      | up and down by a factor of two or more. It prevents                                                                |
|      |           |                                      | the motor going out of regulation, but it also prevents                                                            |
|      |           |                                      | power down below the regulation limit.                                                                             |
|      |           |                                      | DIVIM OFS - O allows automatic scaling to low DIVIM Juty                                                           |
|      |           |                                      | <i>PWM_OFS</i> > 0 allows automatic scaling to low PWM duty cycles even below the lower regulation threshold. This |
|      |           |                                      |                                                                                                                    |
|      |           |                                      | allows low (standstill) current settings based on the actual (hold) current scale (register IHOLD IRUN).           |
|      |           |                                      | actual (nota) current scale (register InolD_IKON).                                                                 |
|      |           |                                      |                                                                                                                    |

www.trinamic.com

## 6.5.5 DRV\_STATUS - StallGuard2 Value and Driver Error Flags

| <b>0</b> x6F         | 0x6F: DRV_STATUS – STALLGUARD2 VALUE AND DRIVER ERROR FLAGS |                                                |                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|----------------------|-------------------------------------------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit                  | Name                                                        | Function                                       | Comment                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 31                   | stst                                                        | standstill indicator                           | This flag indicates motor stand still in each operation mode.<br>This occurs 2^20 clocks after the last step pulse.                                                                                                                                                                                                                                                                                        |  |
| 30                   | olb                                                         | open load indicator<br>phase B                 | 1: Open load detected on phase A or B.<br><i>Hint:</i> This is just an informative flag. The driver takes no action                                                                                                                                                                                                                                                                                        |  |
| 29                   | ola                                                         | open load indicator<br>phase A                 | upon it. False detection may occur in fast motion and standstill. Check during slow motion, only.                                                                                                                                                                                                                                                                                                          |  |
| 28                   | s2gb                                                        | short to ground indicator phase B              | 1: Short to GND detected on phase A or B. The driver becomes disabled. The flags stay active, until the driver is disabled by                                                                                                                                                                                                                                                                              |  |
| 27                   | s2ga                                                        | short to ground<br>indicator phase A           | software ( <i>TOFF</i> =0) or by the ENN input.                                                                                                                                                                                                                                                                                                                                                            |  |
| 26                   | otpw                                                        | overtemperature pre-<br>warning flag           | 1: Overtemperature pre-warning threshold is exceeded.<br>The overtemperature pre-warning flag is common for both<br>bridges.                                                                                                                                                                                                                                                                               |  |
| 25                   | ot                                                          | overtemperature flag                           | 1: Overtemperature limit has been reached. Drivers become disabled until <i>otpw</i> is also cleared due to cooling down of the IC.<br>The overtemperature flag is common for both bridges.                                                                                                                                                                                                                |  |
| 24                   | StallGuard                                                  | StallGuard2 st <mark>atus</mark>               | 1: Motor stall detected (SG_RESULT=0) or DcStep stall in DcStep mode.                                                                                                                                                                                                                                                                                                                                      |  |
| 23<br>22<br>21       | -                                                           | reserved                                       | Ignore these bits                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 20<br>19<br>18<br>17 | CS<br>ACTUAL                                                | actual motor current /<br>smart energy current | Actual current control scaling, for monitoring smart energy current scaling controlled via settings in register <i>COOLCONF</i> , or for monitoring the function of the automatic current scaling.                                                                                                                                                                                                         |  |
| 16<br>15             | fsactive                                                    | full step active<br>indicator                  | 1: Indicates that the driver has switched to fullstep as defined by chopper mode settings and velocity thresholds.                                                                                                                                                                                                                                                                                         |  |
| 14                   | stealth                                                     | StealthChop indicator                          | 1: Driver operates in StealthChop mode                                                                                                                                                                                                                                                                                                                                                                     |  |
| 13                   | s2vsb                                                       | short to supply<br>indicator phase B           | 1: Short to supply detected on phase A or B. The driver becomes disabled. The flags stay active, until the driver is                                                                                                                                                                                                                                                                                       |  |
| 12                   | s2vsa                                                       | short to supply indicator phase A              | disabled by software ( <i>TOFF</i> =0) or by the ENN input. Sense resistor voltage drop is included in the measurement!                                                                                                                                                                                                                                                                                    |  |
| 11                   | -                                                           | reserved                                       | Ign <mark>ore this</mark> bit                                                                                                                                                                                                                                                                                                                                                                              |  |
| 10                   | -                                                           | reserved                                       | Ignore this bit                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 9                    | SG_                                                         | StallGuard2 result                             | Mechanical load measurement:                                                                                                                                                                                                                                                                                                                                                                               |  |
| 8                    | RESULT                                                      | respectively PWM on                            | The StallGuard2 result gives a means to measure mechanical motor load. A higher value means lower mechanical load. A                                                                                                                                                                                                                                                                                       |  |
| 7                    |                                                             | time for coil A in stand                       | value of 0 signals highest load. With optimum SG7 setting,                                                                                                                                                                                                                                                                                                                                                 |  |
| 6                    |                                                             | still for motor<br>temperature detection       | this is an indicator for a motor stall. The stall detection                                                                                                                                                                                                                                                                                                                                                |  |
| 5                    |                                                             | temperature detection                          | compares SG_RESULT to 0 in order to detect a stall. SG_RESULT                                                                                                                                                                                                                                                                                                                                              |  |
| 4                    |                                                             |                                                | is used as a base for CoolStep operation, by comparing it to a                                                                                                                                                                                                                                                                                                                                             |  |
| 2                    |                                                             |                                                | programmable upper and a lower limit. It is not applicable in StealthChop mode.                                                                                                                                                                                                                                                                                                                            |  |
| 1                    | -                                                           |                                                | StallGuard2 works best with microstep operation or DcStep.                                                                                                                                                                                                                                                                                                                                                 |  |
| 0                    |                                                             |                                                | Temperature measurement:<br>In standstill, no StallGuard2 result can be obtained. <i>SG_RESULT</i> shows the chopper on-time for motor coil A instead. Move the motor to a determined microstep position at a certain current setting to get a rough estimation of motor temperature by a reading the chopper on-time. As the motor heats up, its coil resistance rises and the chopper on-time increases. |  |

www.trinamic.com

## 7 StealthChop<sup>™</sup>

StealthChop is an extremely quiet mode of operation for stepper motors. It is based on a voltage mode PWM. In case of standstill and at low velocities, the motor is absolutely noiseless. Thus, StealthChop operated stepper motor applications are very suitable for indoor or home use. The motor operates absolutely free of vibration at low velocities.

With StealthChop, the motor current is applied by driving a certain effective voltage into the coil, using a voltage mode PWM. With the enhanced StealthChop2, the driver automatically adapts to the application for best performance. No more configurations are required. Optional configuration allows for tuning the setting in special cases, or for storing initial values for the automatic adaptation algorithm. For high velocity drives SpreadCycle should be considered in combination with StealthChop.



Figure 7.1 Motor coil sine wave current with StealthChop (measured with current probe)

## 7.1 Automatic Tuning

StealthChop2 integrates an automatic tuning procedure (AT), which adapts the most important operating parameters to the motor automatically. This way, StealthChop2 allows high motor dynamics and supports powering down the motor to very low currents. Just two steps have to be respected by the motion controller for best results: Start with the motor in standstill, but powered with nominal run current (AT#1). Move the motor at a medium velocity, e.g. as part of a homing procedure (AT#2). Figure 7.2 shows the tuning procedure.

Border conditions for AT#1 and AT#2 are shown in the following table:



www.trinamic.com

| AUTON | MATIC TUNING 1    | IMING AND BORDER CONDITIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                      |
|-------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| Step  | Parameter         | Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Required Duration                                                    |
| AT#1  | PWM_<br>OFS_AUTO  | <ul> <li>Motor in standstill and actual current scale (CS) is identical to run current (IRUN).</li> <li>If standstill reduction is enabled, an initial step pulse switches the drive back to run current, or set IHOLD to IRUN.</li> <li>Pin VS at operating level.</li> <li>Attention: Driver may reduce chopper frequency during AT#1. Use reduced standstill current IHOLD</li> <li>If standstill current in the prevent extended periods of time at lower chopper frequency</li> </ul> | ≤ 2^20+2*2^18 t <sub>CLK</sub> ,<br>≤ 130ms<br>(with internal clock) |
| AT#2  | PWM_<br>GRAD_AUTO | <ul> <li>Move motor at a velocity, where a significant amount of back EMF is generated and where the full run current can be reached. Conditions:</li> <li>1.5 * PWM_OFS_AUTO &lt; PWM_SCALE_SUM &lt; 4 * PWM_OFS_AUTO</li> <li>PWM_SCALE_SUM &lt; 255.</li> <li>Hint: A typical range is 60-300 RPM.</li> </ul>                                                                                                                                                                           | for a change of +/-1.<br>For a typical motor with                    |

#### Hint:

Determine best conditions for automatic tuning with the evaluation board.

Use application specific parameters for *PWM\_GRAD* and *PWM\_OFS* for initialization in firmware to provide initial tuning parameters.

Monitor *PWM\_SCALE\_AUTO* going down to zero during the constant velocity phase in AT#2 tuning. This indicates a successful tuning.

#### Attention:

Operating in StealthChop without proper tuning can lead to high motor currents during a deceleration ramp, especially with low resistive motors and fast deceleration settings. Follow the automatic tuning process and check optimum tuning conditions using the evaluation board. It is recommended to use an initial value for settings *PWM\_OFS* and *PWM\_GRAD* determined per motor type.

Protect the power stage and supply by additionally tuning the overcurrent protection.

Known Limitations TMC5160 non-A-version only:

Successful completion of AT#1 tuning phase is not safely detected by the TMC5160. It will require multiple motor start / stop events to safely detect completion.

Successful determination is mandatory for AT#2: Tuning of *PWM\_GRAD* will not start when AT#1 has not completed.

Successful completion of AT#1 and AT#2 only can be checked by monitoring *PWM\_SCALE\_AUTO* approaching 0 during AT#2 motion.

#### Solution a):

Complete automatic tuning phase AT#1 process, by using a slow-motion sequence which leads to standstill detection in between of each two steps. Use a velocity of 8 (6 Hz) or lower and execute minimum 10 steps during AT#1 phase.

#### Solution b):

Store initial parameters for *PWM\_GRAD\_AUTO* for the application. Therefore, use the motor and operating conditions determined for the application and do a complete automatic tuning sequence (refer to *a*)). Store the resulting *PWM\_GRAD\_AUTO* value and use it for initialization of *PWM\_GRAD*. With this, tuning of AT#2 phase is not mandatory in the application and can be skipped. Automatic tuning will further optimize settings during operation. Combine with a) if desired.

#### www.trinamic.com





#### Attention

Modifying *GLOBALSCALER* or VS voltage invalidates the result of the automatic tuning process. Motor current regulation cannot compensate significant changes until next AT#1 phase. Automatic tuning adapts to changed conditions whenever AT#1 and AT#2 conditions are fulfilled in the later operation.

www.trinamic.com

## 7.2 StealthChop Options

In order to match the motor current to a certain level, the effective PWM voltage becomes scaled depending on the actual motor velocity. Several additional factors influence the required voltage level to drive the motor at the target current: The motor resistance, its back EMF (i.e. directly proportional to its velocity) as well as the actual level of the supply voltage. Two modes of PWM regulation are provided: The automatic tuning mode (AT) using current feedback (*pwm\_autoscale* = 1, *pwm\_autograd* = 1) and a feed forward velocity-controlled mode (*pwm\_autoscale* = 0). The feed forward velocity-controlled mode will not react to a change of the supply voltage or to events like a motor stall, but it provides very stable amplitude. It does not use nor require any means of current measurement. This is perfect when motor type and supply voltage are well known. Therefore, we recommend the automatic mode, unless current regulation is not satisfying in the given operating conditions.

It is recommended to use application specific initial tuning parameters, fitting the motor type and supply voltage. Additionally, operate in automatic tuning mode in order to respond to parameter change, e.g. due to motor heat-up or change of supply voltage.

Non-automatic mode (*pwm\_autoscale=0*) should be taken into account only with well-known motor and operating conditions. In this case, careful programming via the interface is required. The operating parameters *PWM\_GRAD* and *PWM\_OFS* can be determined in automatic tuning mode initially.

The StealthChop PWM frequency can be chosen in four steps in order to adapt the frequency divider to the frequency of the clock source. A setting in the range of 20-50kHz is good for most applications. It balances low current ripple and good higher velocity performance vs. dynamic power dissipation.

| CHOICE OF PWM FREQUENCY FOR STEALTHCHOP |                                           |                                          |                                          |                                          |  |
|-----------------------------------------|-------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|--|
| Clock frequency                         | PWM_FREQ=%00                              | PWM_FREQ=%01                             | PWM_FREQ=%10                             | PWM_FREQ=%11                             |  |
| <b>f</b> <sub>CLK</sub>                 | f <sub>PWM</sub> =2/1024 f <sub>CLK</sub> | f <sub>PWM</sub> =2/683 f <sub>CLK</sub> | f <sub>PWM</sub> =2/512 f <sub>CLK</sub> | f <sub>PWM</sub> =2/410 f <sub>CLK</sub> |  |
| 18MHz                                   | 35.2kHz                                   | 52.7kHz                                  | 70.3kHz                                  | 87.8kHz                                  |  |
| 16MHz                                   | 31.3kHz                                   | 46.9kHz                                  | 62.5kHz                                  | 78.0kHz                                  |  |
| 12MHz (internal)                        | 23.4kHz                                   | 35.1kHz                                  | 46.9kHz                                  | 58.5kHz                                  |  |
| 10MHz                                   | 19.5kHz                                   | 29.3kHz                                  | 39.1kHz                                  | 48.8kHz                                  |  |
| 8MHz                                    | 15.6kHz                                   | 23.4kHz                                  | 31.2kHz                                  | 39.0kHz                                  |  |

Table 7.1 Choice of PWM frequency - green / light green: recommended

## 7.3 StealthChop Current Regulator

In StealthChop voltage PWM mode, the autoscaling function (pwm\_autoscale = 1, pwm\_auto\_grad = 1) regulates the motor current to the desired current setting. Automatic scaling is used as part of the automatic tuning process (AT), and for subsequent tracking of changes within the motor parameters. The driver measures the motor current during the chopper on time and uses a proportional regulator to regulate PWM SCALE AUTO in order match the motor current to the target current. PWM REG is the proportionality coefficient for this regulator. Basically, the proportionality coefficient should be as small as possible in order to get a stable and soft regulation behavior, but it must be large enough to allow the driver to quickly react to changes caused by variation of the motor target current (e.g. change of VREF). During initial tuning step AT#2, PWM\_REG also compensates for the change of motor velocity. Therefore, a high acceleration during AT#2 will require a higher setting of PWM\_REG. With careful selection of homing velocity and acceleration, a minimum setting of the regulation gradient often is sufficient (PWM REG=1). PWM REG setting should be optimized for the fastest required acceleration and deceleration ramp (compare Figure 7.3 and Figure 7.4). The guality of the setting PWM REG in phase AT#2 and the finished automatic tuning procedure (or non-automatic settings for PWM\_OFS and PWM\_GRAD) can be examined when monitoring motor current during an acceleration phase Figure 7.5.

www.trinamic.com



Figure 7.3 Scope shot: good setting for PWM\_REG



Figure 7.4 Scope shot: too small setting for PWM\_REG during AT#2



Figure 7.5 Successfully determined PWM\_GRAD(\_AUTO) and PWM\_OFS(\_AUTO)

www.trinamic.com

#### Quick Start

For a quick start, see the Quick Configuration Guide in chapter 22.

#### 7.3.1 Lower Current Limit

The StealthChop current regulator imposes a lower limit for motor current regulation. As the coil current can be measured in the shunt resistor during chopper on phase only, a minimum chopper duty cycle allowing coil current regulation is given by the blank time as set by *TBL* and by the chopper frequency setting. Therefore, the motor specific minimum coil current in StealthChop autoscaling mode rises with the supply voltage and with the chopper frequency. A lower blanking time allows a lower current limit. It is important for the correct determination of *PWM\_OFS\_AUTO*, that in AT#1 the run current set by the sense resistor, *GLOBALSCALER* and *IRUN* is well within the regulation range. Lower currents (e.g. for standstill power down) are automatically realized based on *PWM\_OFS\_AUTO* and *PWM\_GRAD\_AUTO* respectively based on *PWM\_OFS* and *PWM\_GRAD* with non-automatic current scaling. The freewheeling option allows going to zero motor current.

Lower motor coil current limit for StealthChop2 automatic tuning:

 $I_{Lower\ Limit} = t_{BLANK} * f_{PWM} * \frac{V_M}{R_{COIL}}$ 

With  $V_M$  the motor supply voltage and  $R_{COIL}$  the motor coil resistance.

I<sub>Lower Limit</sub> can be treated as a thumb value for the minimum nominal *IRUN* motor current setting. In case the lower current limit is not sufficient to reach the desired setting, the driver will retry with a lower chopper frequency in step AT#1, only.

 $f_{PWM}$  is the chopper frequency as determined by setting *PWM\_FREQ*. In AT#1, the driver tries a lower, (roughly half frequency), in case it cannot reach the current. The frequency will remain active in standstill, while currentscale *CS=IRUN*. With automatic standstill reduction, this is a short moment.

#### EXAMPLE:

A motor has a coil resistance of 5 $\Omega$ , the supply voltage is 24V. With *TBL*=%01 and *PWM\_FREQ*=%00, t<sub>BLANK</sub> is 24 clock cycles, f<sub>PWM</sub> is 2/(1024 clock cycles):

$$I_{Lower \ Limit} = 24 \ t_{CLK} * \frac{2}{1024} \frac{24V}{t_{CLK}} * \frac{24V}{5\Omega} = \frac{24}{512} * \frac{24V}{5\Omega} = 225mA$$

This means, the motor target current for automatic tuning must be 225mA or more, taking into account all relevant settings. This lower current limit also applies for modification of the motor current via the *GLOBALSCALER*.

#### Attention

For automatic tuning, a lower coil current limit applies. The motor current in automatic tuning phase AT#1 must exceed this lower limit. ILOWER LIMIT can be calculated or measured using a current probe. Setting the motor run-current or hold-current below the lower current limit during operation by modifying *IRUN* and *IHOLD* is possible after successful automatic tuning.

The lower current limit also limits the capability of the driver to respond to changes of *GLOBALSCALER*.

www.trinamic.com

#### 7.4 Velocity Based Scaling

Velocity based scaling scales the StealthChop amplitude based on the time between each two steps, i.e. based on *TSTEP*, measured in clock cycles. This concept basically does not require a current measurement, because no regulation loop is necessary. A pure velocity-based scaling is available via programming, only, when setting *pwm\_autoscale* = 0. The basic idea is to have a linear approximation of the voltage required to drive the target current into the motor. The stepper motor has a certain coil resistance and thus needs a certain voltage amplitude to yield a target current based on the basic formula I=U/R. With R being the coil resistance, U the supply voltage scaled by the PWM value, the current I results. The initial value for *PWM\_OFS* can be calculated:

$$PWM_OFS = \frac{374 * R_{COIL} * I_{COIL}}{V_M}$$

With  $V_M$  the motor supply voltage and  $I_{COIL}$  the target RMS current

The effective PWM voltage  $U_{PWM}$  (1/SQRT(2) x peak value) results considering the 8 bit resolution and 248 sine wave peak for the actual PWM amplitude shown as *PWM\_SCALE*:

 $U_{PWM} = V_M * \frac{PWM\_SCALE}{256} * \frac{248}{256} * \frac{1}{\sqrt{2}} = V_M * \frac{PWM\_SCALE}{374}$ 

With rising motor velocity, the motor generates an increasing back EMF voltage. The back EMF voltage is proportional to the motor velocity. It reduces the PWM voltage effective at the coil resistance and thus current decreases. The TMC5160 provides a second velocity dependent factor (*PWM\_GRAD*) to compensate for this. The overall effective PWM amplitude (*PWM\_SCALE\_SUM*) in this mode automatically is calculated in dependence of the microstep frequency as:

 $PWM\_SCALE\_SUM = PWM\_OFS + PWM\_GRAD * 256 * \frac{f_{STEP}}{f_{STEP}}$ 

With  $f_{STEP}$  being the microstep frequency for 256 microstep resolution equivalent and  $f_{CLK}$  the clock frequency supplied to the driver or the actual internal frequency

As a first approximation, the back EMF subtracts from the supply voltage and thus the effective current amplitude decreases. This way, a first approximation for *PWM\_GRAD* setting can be calculated:

$$PWM\_GRAD = C_{BEMF} \left[ \frac{V}{\frac{rad}{s}} \right] * 2\pi * \frac{f_{CLK} * 1.46}{V_M * MSPR}$$

C<sub>BEMF</sub> is the back EMF constant of the motor in Volts per radian/second. MSPR is the number of microsteps per rotation, e.g. 51200 = 256µsteps multiplied by 200 fullsteps for a 1.8° motor.

www.trinamic.com



Figure 7.6 Velocity based PWM scaling (pwm\_autoscale=0)

#### Hint

The values for *PWM\_OFS* and *PWM\_GRAD* can easily be optimized by tracing the motor current with a current probe on the oscilloscope. Alternatively, automatic tuning determines these values and they can be read out from *PWM\_OFS\_AUTO* and *PWM\_GRAD\_AUTO*.

#### UNDERSTANDING THE BACK EMF CONSTANT OF A MOTOR

The back EMF constant is the voltage a motor generates when turned with a certain velocity. Often motor datasheets do not specify this value, as it can be deducted from motor torque and coil current rating. Within SI units, the numeric value of the back EMF constant  $C_{BEMF}$  has the same numeric value as the numeric value of the torque constant. For example, a motor with a torque constant of 1 Nm/A would have a  $C_{BEMF}$  of 1V/rad/s. Turning such a motor with 1 rps (1 rps = 1 revolution per second = 6.28 rad/s) generates a back EMF voltage of 6.28V. Thus, the back EMF constant can be calculated as:

 $C_{BEMF}\left[\frac{V}{rad/s}\right] = \frac{HoldingTorque[Nm]}{2 * I_{COILNOM}[A]}$ 

 $I_{\text{COILNOM}}$  is the motor's rated phase current for the specified holding torque

HoldingTorque is the motor specific holding torque, i.e. the torque reached at I<sub>COILNOM</sub> on both coils. The torque unit is [Nm] where 1Nm = 100Ncm = 1000mNm.

The voltage is valid as RMS voltage per coil, thus the nominal current is multiplied by 2 in this formula, since the nominal current assumes a full step position, with two coils operating.

## 7.5 Combining StealthChop and SpreadCycle CON

For applications requiring high velocity motion, SpreadCycle may bring more stable operation in the upper velocity range. To combine no-noise operation with highest dynamic performance, the TMC5160 allows combining StealthChop and SpreadCycle based on a velocity threshold (Figure 7.7). With this, StealthChop is only active at low velocities.

www.trinamic.com



#### Figure 7.7 TPWMTHRS for optional switching to SpreadCycle

As a first step, both chopper principles should be parameterized and optimized individually. In a next step, a transfer velocity has to be fixed. For example, StealthChop operation is used for precise low speed positioning, while SpreadCycle shall be used for highly dynamic motion. *TPWMTHRS* determines the transition velocity. Read out *TSTEP* when moving at the desired velocity and program the resulting value to *TPWMTHRS*. Use a low transfer velocity to avoid a jerk at the switching point.

A jerk occurs when switching at higher velocities, because the back-EMF of the motor (which rises with the velocity) causes a phase shift of up to 90° between motor voltage and motor current. So when switching at higher velocities between voltage PWM and current PWM mode, this jerk will occur with increased intensity. A high jerk may even produce a temporary overcurrent condition (depending on the motor coil resistance). At low velocities (e.g. 1 to a few 10 RPM), it can be completely neglected for most motors. Therefore, consider the switching jerk when choosing *TPWMTHRS*. Set *TPWMTHRS* zero if you want to work with StealthChop only.

When enabling the StealthChop mode the first time using automatic current regulation, the motor must be at stand still in order to allow a proper current regulation. When the drive switches to StealthChop at a higher velocity, StealthChop logic stores the last current regulation setting until the motor returns to a lower velocity again. This way, the regulation has a known starting point when returning to a lower velocity, where StealthChop becomes re-enabled. Therefore, neither the velocity threshold nor the supply voltage must be considerably changed during the phase while the chopper is switched to a different mode, because otherwise the motor might lose steps or the instantaneous current might be too high or too low.

A motor stall or a sudden change in the motor velocity may lead to the driver detecting a short circuit or to a state of automatic current regulation, from which it cannot recover. Clear the error flags and restart the motor from zero velocity to recover from this situation.

Hint

Start the motor from standstill when switching on StealthChop the first time and keep it stopped for at least 128 chopper periods to allow StealthChop to do initial standstill current control.

65

# published by WWW.SKYTECH.IR

www.trinamic.com

## 7.6 Flags in StealthChop

As StealthChop uses voltage mode driving, status flags based on current measurement respond slower, respectively the driver reacts delayed to sudden changes of back EMF, like on a motor stall.

#### Attention

A motor stall, or abrupt stop of the motion during operation in StealthChop can lead to a overcurrent condition. Depending on the previous motor velocity, and on the coil resistance of the motor, it significantly increases motor current for a time of several 10ms. With low velocities, where the back EMF is just a fraction of the supply voltage, there is no danger of triggering the short detection.

Hint

Tune low side driver overcurrent detection to safely trigger upon motor stall, when using StealthChop. This will avoid high peak current draw from the power supply.

#### 7.6.1 Open Load Flags

In StealthChop mode, status information is different from the cycle-by-cycle regulated SpreadCycle mode. OLA and OLB show if the current regulation sees that the nominal current can be reached on both coils.

- A flickering OLA or OLB can result from asymmetries in the sense resistors or in the motor coils.
- An interrupted motor coil leads to a continuously active open load flag for the coil.
- One or both flags are active, if the current regulation did not succeed in scaling up to the full target current within the last few fullsteps (because no motor is attached or a high velocity exceeds the PWM limit).

If desired, do an on-demand open load test using the SpreadCycle chopper, as it delivers the safest result. With StealthChop, *PWM\_SCALE\_SUM* can be checked to detect the correct coil resistance.

#### 7.6.2 PWM\_SCALE\_SUM Informs about the Motor State

Information about the motor state is available with automatic scaling by reading out *PWM\_SCALE\_SUM*. As this parameter reflects the actual voltage required to drive the target current into the motor, it depends on several factors: motor load, coil resistance, supply voltage, and current setting. Therefore, an evaluation of the *PWM\_SCALE\_SUM* value allows checking the motor operation point. When reaching the limit (255), the current regulator cannot sustain the full motor current, e.g. due to a drop in supply volage.

## 7.7 Freewheeling and Passive Braking

StealthChop provides different options for motor standstill. These options can be enabled by setting the standstill current *IHOLD* to zero and choosing the desired option using the *FREEWHEEL* setting. The desired option becomes enabled after a time period specified by *TPOWERDOWN* and *IHOLDDELAY*. Current regulation becomes frozen once the motor target current is at zero current in order to ensure a quick startup. With the freewheeling options, both freewheeling and passive braking can be realized. Passive braking is an effective eddy current motor braking, which consumes a minimum of energy, because no active current is driven into the coils. However, passive braking will allow slow turning of the motor when a continuous torque is applied.

Hint

Operate the motor within your application when exploring StealthChop. Motor performance often is better with a mechanical load, because it prevents the motor from stalling due mechanical oscillations which can occur without load.

www.trinamic.com

| PARAMETERS | RELATED TO STEALTHCHOP                                                                             |         |                                              |
|------------|----------------------------------------------------------------------------------------------------|---------|----------------------------------------------|
| Parameter  | Description                                                                                        | Setting | Comment                                      |
| en_spread_ | General disable for use of StealthChop (register                                                   | 1       | Do not use StealthChop                       |
| cycle      | GCONF).                                                                                            | 0       | StealthChop enabled                          |
| TPWMTHRS   | Specifies the upper velocity for operation in                                                      | 0       | StealthChop is disabled if                   |
|            | StealthChop. Entry the TSTEP reading (time                                                         |         | TSTEP falls TPWMTHRS                         |
|            | between two microsteps) when operating at the                                                      |         |                                              |
|            | desired threshold velocity.                                                                        |         |                                              |
| PWM_LIM    | Limiting value for limiting the current jerk when                                                  | 0 15    | Upper four bits of 8 bit                     |
|            | switching from SpreadCycle to StealthChop.                                                         |         | amplitude limit                              |
|            | Reduce the value to yield a lower current jerk.                                                    |         | (Default=12)                                 |
| pwm_       | Enable automatic current scaling using current                                                     | 0       | Forward controlled mode                      |
| autoscale  | measurement. If off, use forward controlled                                                        | 1       | Automatic scaling with                       |
|            | velocity-based mode.                                                                               |         | current regulator                            |
| pwm_       | Enable automatic tuning of PWM_GRAD_AUTO                                                           | 0       | disable, use PWM_GRAD                        |
| autograd   |                                                                                                    |         | from register instead                        |
| 2          |                                                                                                    | 1       | enable                                       |
| PWM FREQ   | PWM frequency selection. Use the lowest setting                                                    | 0       | f <sub>PWM</sub> =2/1024 f <sub>CLK</sub>    |
|            | giving good results. The frequency measured at                                                     |         | f <sub>PWM</sub> =2/683 f <sub>CLK</sub>     |
|            | each of the chopper outputs is half of the                                                         |         | f <sub>PWM</sub> =2/512 f <sub>CLK</sub>     |
|            | effective chopper frequency f <sub>PWM</sub> .                                                     | 3       | f <sub>PWM</sub> =2/410 f <sub>CLK</sub>     |
| PWM REG    | User defined PWM amplitude regulation loop P-                                                      |         | Results in 0.5 to 7.5 steps                  |
| FVVM_KEG   | coefficient. A higher value leads to a higher                                                      | T T)    | for PWM SCALE AUTO                           |
|            |                                                                                                    |         |                                              |
| PWM_OFS    | adaptation speed when <i>pwm_autoscale</i> =1.<br>User defined PWM amplitude (offset) for velocity | 0 255   | regulator per fullstep<br>PWM OFS=0 disables |
| PVVM_OFS   |                                                                                                    | 0 200   | linear current scaling                       |
|            | based scaling and initialization value for automatic tuning of <i>PWM_OFFS_AUTO</i> .              |         | based on current setting                     |
| PWM_GRAD   | User defined PWM amplitude (gradient) for                                                          | 0 255   | based on current setting                     |
| FWM_GRAD   | velocity based scaling and initialization value for                                                | 0 233   |                                              |
|            | automatic tuning of PWM_GRAD_AUTO.                                                                 |         |                                              |
| FREEWHEEL  | Stand still option when motor current setting is                                                   | 0       | Normal operation                             |
|            | zero (I_HOLD=0). Only available with StealthChop                                                   |         | Freewheeling                                 |
|            | enabled. The freewheeling option makes the                                                         |         | Coil short via LS drivers                    |
|            | motor easy movable, while both coil short options                                                  |         | Coil short cia HS drivers                    |
|            | realize a passive brake.                                                                           | 5       |                                              |
| PWM SCALE  | Read back of the actual StealthChop voltage PWM                                                    | -255    | (read only) Scaling value                    |
| AUTO       | scaling correction as determined by the current                                                    |         | becomes frozen when                          |
|            | regulator. Shall regulate close to 0 during tuning.                                                |         | operating in SpreadCycle                     |
| PWM_GRAD   | Allow monitoring of the automatic tuning and                                                       | 0 255   | (read only)                                  |
| AUTO       | determination of initial values for PWM_OFS and                                                    |         |                                              |
| PWM OFS    | PWM GRAD.                                                                                          | C T     | DONIC                                        |
| AUTO       |                                                                                                    |         |                                              |
| TOFF       | General enable for the motor driver, the actual                                                    | 0       | Driver off                                   |
|            | value does not influence StealthChop                                                               | 1 15    | Driver enabled                               |
| TBL        | Comparator blank time. This time needs to safely                                                   |         | 16 t <sub>CLK</sub>                          |
|            | cover the switching event and the duration of the                                                  |         | 24 t <sub>CLK</sub>                          |
|            | ringing on the sense resistor. Choose a setting of                                                 |         | 36 t <sub>CLK</sub>                          |
|            | 1 or 2 for typical applications. For higher                                                        |         | 54 t <sub>CLK</sub>                          |
|            | capacitive loads, 3 may be required. Lower                                                         | د       |                                              |
|            | settings allow StealthChop to regulate down to                                                     |         |                                              |
|            | lower coil current values.                                                                         |         |                                              |
|            |                                                                                                    | 1       | l                                            |

www.trinamic.com

## 8 SpreadCycle and Classic Chopper

While StealthChop is a voltage mode PWM controlled chopper, SpreadCycle is a cycle-by-cycle current control. Therefore, it can react extremely fast to changes in motor velocity or motor load. The currents through both motor coils are controlled using choppers. The choppers work independently of each other. In Figure 8.1 the different chopper phases are shown.



#### Figure 8.1 Chopper phases

Although the current could be regulated using only on phases and fast decay phases, insertion of the slow decay phase is important to reduce electrical losses and current ripple in the motor. The duration of the slow decay phase is specified in a control parameter and sets an upper limit on the chopper frequency. The current comparator can measure coil current during phases when the current flows through the sense resistor, but not during the slow decay phase, so the slow decay phase is terminated by a timer. The on phase is terminated by the comparator when the current through the coil reaches the target current. The fast decay phase may be terminated by either the comparator or another timer.

When the coil current is switched, spikes at the sense resistors occur due to charging and discharging parasitic capacitances. During this time, typically one or two microseconds, the current cannot be measured. Blanking is the time when the input to the comparator is masked to block these spikes.

There are two cycle-by-cycle chopper modes available: a new high-performance chopper algorithm called SpreadCycle and a proven constant off-time chopper mode. The constant off-time mode cycles through three phases: on, fast decay, and slow decay. The SpreadCycle mode cycles through four phases: on, slow decay, fast decay, and a second slow decay.

The chopper frequency is an important parameter for a chopped motor driver. A too low frequency might generate audible noise. A higher frequency reduces current ripple in the motor, but with a too high frequency magnetic losses may rise. Also power dissipation in the driver rises with increasing frequency due to the increased influence of switching slopes causing dynamic dissipation. Therefore, a compromise needs to be found. Most motors are optimally working in a frequency range of 16 kHz to 30 kHz. The chopper frequency is influenced by a number of parameter settings as well as by the motor inductivity and supply voltage.

#### Hint

www.trinamic.com

A chopper frequency in the range of 16 kHz to 30 kHz gives a good result for most motors when using SpreadCycle. A higher frequency leads to increased switching losses.

| Parameter | Description                                                                                                                                                                                                       | Setting | Comment                                                                                                              |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------------------------------------------------------------------------------------------------------------------|
| TOFF      | Sets the slow decay time (off time). This setting also                                                                                                                                                            | 0       | chopper off                                                                                                          |
|           | limits the maximum chopper frequency.<br>For operation with StealthChop, this parameter is not<br>used, but it is required to enable the motor. In case of<br>operation with StealthChop only, any setting is OK. |         | off time setting<br>N <sub>CLK</sub> = 24 + 32* <i>TOFF</i><br>(1 will work with minimum<br>blank time of 24 clocks) |
|           | Setting this parameter to zero completely disables all driver transistors and the motor can free-wheel.                                                                                                           |         |                                                                                                                      |
| TBL       | Selects the comparator <i>blank time</i> . This time needs to                                                                                                                                                     | 0       | 16 t <sub>CLK</sub>                                                                                                  |
|           | safely cover the switching event and the duration of the ringing on the sense resistor. For most applications, a setting of 1 or 2 is good. For highly capacitive loads,                                          |         | 24 t <sub>CLK</sub>                                                                                                  |
|           |                                                                                                                                                                                                                   |         | 36 t <sub>CLK</sub>                                                                                                  |
|           | e.g. when filter networks are used, a setting of 2 or 3 will be required.                                                                                                                                         | 3       | 54 t <sub>CLK</sub>                                                                                                  |
| chm       | Selection of the chopper mode                                                                                                                                                                                     | 0       | SpreadCycle                                                                                                          |
|           |                                                                                                                                                                                                                   | 1       | classic const. off time                                                                                              |
| TPFD      | Adds passive fast decay time after bridge polarity                                                                                                                                                                |         | Fast decay time in multiple                                                                                          |
|           | change. Starting from 0, increase value, in case the                                                                                                                                                              | 015     | of 128 clocks (128 clocks                                                                                            |
|           | motor suffers from mid-range resonances.                                                                                                                                                                          |         | are roughly 10µs)                                                                                                    |
|           |                                                                                                                                                                                                                   |         |                                                                                                                      |

#### SpreadCycle Chopper 8.1

The SpreadCycle (patented) chopper algorithm is a precise and simple to use chopper mode which automatically determines the optimum length for the fast-decay phase. The SpreadCycle will provide superior microstepping quality even with default settings. Several parameters are available to optimize the chopper to the application.

Each chopper cycle is comprised of an on phase, a slow decay phase, a fast decay phase and a second slow decay phase (see Figure 8.3). The two slow decay phases and the two blank times per chopper cycle put an upper limit to the chopper frequency. The slow decay phases typically make up for about 30%-70% of the chopper cycle in standstill and are important for low motor and driver power dissipation.

Calculation of a starting value for the slow decay time TOFF:



The hysteresis start setting forces the driver to introduce a minimum amount of current ripple into the motor coils. The current ripple must be higher than the current ripple which is caused by resistive losses in the motor in order to give best microstepping results. This will allow the chopper to precisely regulate the current both for rising and for falling target current. The time required to introduce the current ripple into the motor coil also reduces the chopper frequency. Therefore, a higher hysteresis setting will lead to a lower chopper frequency. The motor inductance limits the

www.trinamic.com

# Three parameters are used for controlling both chopper modes:

ability of the chopper to follow a changing motor current. Further the duration of the on phase and the fast decay must be longer than the blanking time, because the current comparator is disabled during blanking.

It is easiest to find the best setting by starting from a low hysteresis setting (e.g. *HSTRT*=0, *HEND*=0) and increasing *HSTRT*, until the motor runs smoothly at low velocity settings. This can best be checked when measuring the motor current either with a current probe or by probing the sense resistor voltages (see Figure 8.2). Checking the sine wave shape near zero transition will show a small ledge between both half waves in case the hysteresis setting is too small. At medium velocities (i.e. 100 to 400 fullsteps per second), a too low hysteresis setting will lead to increased humming and vibration of the motor.



## Figure 8.2 No ledges in current wave with sufficient hysteresis (magenta: current A, yellow & blue: sense resistor voltages A and B)

A too high hysteresis setting will lead to reduced chopper frequency and increased chopper noise but will not yield any benefit for the wave shape.

#### Quick Start

For a quick start, see the Quick Configuration Guide in chapter 22. For detail procedure see Application Note AN001 - *Parameterization of SpreadCycle* 

As experiments show, the setting is quite independent of the motor, because higher current motors typically also have a lower coil resistance. Therefore choosing a low to medium default value for the hysteresis (for example, effective hysteresis = 4) normally fits most applications. The setting can be optimized by experimenting with the motor: A too low setting will result in reduced microstep accuracy, while a too high setting will lead to more chopper noise and motor power dissipation. When measuring the sense resistor voltage in motor standstill at a medium coil current with an oscilloscope, a too low setting shows a fast decay phase not longer than the blanking time. When the fast decay time becomes slightly longer than the blanking time, the setting is optimum. You can reduce the off-time setting, if this is hard to reach.

The hysteresis principle could in some cases lead to the chopper frequency becoming too low, e.g. when the coil resistance is high when compared to the supply voltage. This is avoided by splitting the hysteresis setting into a start setting (*HSTRT+HEND*) and an end setting (*HEND*). An automatic hysteresis decrementer (HDEC) interpolates between both settings, by decrementing the hysteresis value stepwise each 16 system clocks. At the beginning of each chopper cycle, the hysteresis begins with a value which is the sum of the start and the end values (*HSTRT+HEND*), and decrements during the cycle, until either the chopper cycle ends or the hysteresis end value (*HEND*) is reached. This way,

www.trinamic.com

the chopper frequency is stabilized at high amplitudes and low supply voltage situations, if the frequency gets too low. This avoids the frequency reaching the audible range.



#### Figure 8.3 SpreadCycle chopper scheme showing coil current during a chopper cycle

Two parameters control SpreadCycle mode:

| Parameter | Description                                                                                    | Setting | Comment                  |
|-----------|------------------------------------------------------------------------------------------------|---------|--------------------------|
| HSTRT     | Hysteresis start setting. This value is an offset                                              | 07      | HSTRT=18                 |
|           | from the hysteresis end value HEND.                                                            |         | This value adds to HEND. |
| HEND      | Hysteresis end setting. Sets the hysteresis end                                                | 02      | -31: negative HEND       |
|           | value after a number of decrements. The sum<br>HSTRT+HEND must be ≤16. At a current setting of | 3       | 0: zero HEND             |
|           | max. 30 (amplitude reduced to 240), the sum is not limited.                                    | 415     | 112: positive HEND       |

With HSTRT=0 and HEND=0, the hysteresis is 0 (off).

| EXAMPLE:                                                                                               |                                                             |  |  |
|--------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|--|--|
| A hysteresis of 4 has been chosen. You might decide to not use hysteresis decrement. In this case set: |                                                             |  |  |
| HEND=6                                                                                                 | (sets an effective end value of 6-3=3)                      |  |  |
| HSTRT=0                                                                                                | (sets minimum hysteresis, i.e. 1: 3+1=4)                    |  |  |
| In order to take advantage of the variable hysteresis, we can set most of the value to the HSTRT, i.e. |                                                             |  |  |
| 4, and the remaining 1 to hysteresis end. The resulting configuration register values are as follows:  |                                                             |  |  |
| HEND=0                                                                                                 | (sets an effective end value of -3)                         |  |  |
| HSTRT=6                                                                                                | (sets an effective start value of hysteresis end +7: 7-3=4) |  |  |
|                                                                                                        |                                                             |  |  |
| Hint                                                                                                   |                                                             |  |  |

Highest motor velocities sometimes benefit from setting TOFF to 2 or 3 and a short TBL of 2 or 1.

www.trinamic.com

#### 8.2 Classic Constant Off Time Chopper

The classic constant off time chopper is an alternative to SpreadCycle. Perfectly tuned, it also gives good results. Also, the classic constant off time chopper (automatically) is used in combination with fullstepping in DcStep operation.

The classic constant off-time chopper uses a fixed-time fast decay following each on phase. While the duration of the on phase is determined by the chopper comparator, the fast decay time needs to be long enough for the driver to follow the falling slope of the sine wave, but it should not be so long that it causes excess motor current ripple and power dissipation. This can be tuned using an oscilloscope or evaluating motor smoothness at different velocities. A good starting value is a fast decay time setting similar to the slow decay time setting.



Figure 8.4 Classic const. off time chopper with offset showing coil current

After tuning the fast decay time, the offset should be tuned for a smooth zero crossing. This is necessary because the fast decay phase makes the absolute value of the motor current lower than the target current (see Figure 8.5). If the zero offset is too low, the motor stands still for a short moment during current zero crossing. If it is set too high, it makes a larger microstep. Typically, a positive offset setting is required for smoothest operation.



Three parameters control constant off-time mode:

#### www.trinamic.com

| Parameter        | Description                                                                                                                                                   | Setting | Comment                                                 |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------|
| TFD              | Fast decay time setting. With CHM=1, these bits                                                                                                               |         | slow decay only                                         |
| (fd3 &<br>HSTRT) | control the portion of fast decay for each chopper cycle.                                                                                                     | 115     | duration of fast decay<br>phase                         |
| OFFSET           | Sine wave offset. With CHM=1, these bits control                                                                                                              |         | negative offset: -31                                    |
| (HEND)           | the sine wave offset. A positive offset corrects for                                                                                                          | 3       | no offset: 0                                            |
|                  | zero crossing error.                                                                                                                                          | 415     | positive offset 112                                     |
| disfdcc          | Selects usage of the <i>current comparator</i> for termination of the <i>fast decay</i> cycle. If current comparator is enabled, it terminates the fast decay |         | enable comparator<br>termination of fast decay<br>cycle |
|                  | cycle in case the current reaches a higher negative value than the actual positive value.                                                                     | 1       | end by time only                                        |



www.trinamic.com

# 9 Selecting Sense Resistors

The TMC5160 provides several means to set the motor current: Sense resistors, *GLOBALSCALER* and currentscale *CS*. To adapt a drive to the motor, choose a sense-resistor value fitting or slightly exceeding the maximum desired current at 100% settings of the scalers. Fine-tune the current to the specific motor via the 8 bit *GLOBALSCALER*. Situation specific motor current adaptation is done by 5 bit scalers (actual scale can be read via *CS*), controlled by CoolStep, run- and hold current (*IRUN*, *IHOLD*). This makes the *CS* control compatible to other TRINAMIC ICs.

Set the desired maximum motor current by selecting an appropriate value for the sense resistor. The following table shows the RMS current values which are reached using standard resistors.

|                      | CHOICE OF R <sub>SENSE</sub> AND RESULTING MAX. MOTOR CURRENT<br>WITH GLOBALSCALER=255 |                 |                     |  |  |  |
|----------------------|----------------------------------------------------------------------------------------|-----------------|---------------------|--|--|--|
| $R_{SENSE} [\Omega]$ |                                                                                        | RMS current [A] | Sine wave peak      |  |  |  |
|                      |                                                                                        | (CS=31)         | current [A] (CS=31) |  |  |  |
| 0.22                 |                                                                                        | 1.1             | 1.5                 |  |  |  |
| 0.15                 |                                                                                        | 1.6             | 2.2                 |  |  |  |
| 0.12                 |                                                                                        | 2.0             | 2.8                 |  |  |  |
| 0.10                 |                                                                                        | 2.3             | 3.3                 |  |  |  |
| 0.075                |                                                                                        | 3.1             | 4.4                 |  |  |  |
| 0.066                |                                                                                        | 3.5             | 5.0                 |  |  |  |
| 0.050                |                                                                                        | 4.7             | 6.6                 |  |  |  |
| 0.033                |                                                                                        | 7.1             | 10.0                |  |  |  |
| 0.022                |                                                                                        | 10.6            | 15.0                |  |  |  |

Sense resistors should be carefully selected. The full motor current flows through the sense resistors. Due to chopper operation the sense resistors see pulsed current from the MOSFET bridges. Therefore, a low-inductance type such as film or composition resistors is required to prevent voltage spikes causing ringing on the sense voltage inputs leading to unstable measurement results. Also, a low-inductance, low-resistance PCB layout is essential. A massive ground plane is best. Please also refer to layout considerations in chapter 29.

The sense resistor sets the upper current which can be set by software settings *IRUN*, *IHOLD* and *GLOBALSCALER*. Choose the sense resistor value so that the maximum desired current (or slightly more) flows at the maximum current setting (*GLOBALSCALER* = 0 and *IRUN* = 31).



*GLOBALSCALER* is the global current scaler. A setting of 0 is treated as full scale (256). *CS* is the current scale setting as set by the *IHOLD* and *IRUN* and CoolStep.  $V_{FS}$  is the full scale voltage (please refer to electrical characteristics, V<sub>SRT</sub>). *CUR<sub>A/B</sub>* is the actual value from the internal sine wave table. 248 is the amplitude of the internal sine wave table.

The sense resistor needs to be able to conduct the peak motor coil current in motor standstill conditions, unless standby power is reduced. Under normal conditions, the sense resistor conducts

www.trinamic.com

less than the coil RMS current, because no current flows through the sense resistor during the slow decay phases.

#### CALCULATION OF PEAK SENSE RESISTOR POWER DISSIPATION

 $P_{RSMAX} = I_{COIL}^2 * R_{SENSE}$ 

Hint

For best precision of current setting, it is advised to measure and fine tune the current in the application. Choose the sense resistors to the next value covering the desired motor current. Set *IRUN* to 31 corresponding 100% of the desired motor current and fine-tune motor current using *GLOBALSCALER*.

#### Attention

Be sure to use a symmetrical sense resistor layout and short and straight sense resistor traces of identical length. Well matching sense resistors ensure best performance. A compact layout with massive ground plane is best to avoid parasitic resistance effects.

|                  |                                                                                                                                                                                                                                                                                                                                                                                                                          |         | in the second seco |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameter        | Description                                                                                                                                                                                                                                                                                                                                                                                                              | Setting | Comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| IRUN             | Current scale when motor is running. Scales coil<br>current values as taken from the internal sine<br>wave table. For high precision motor operation,<br>work with a current scaling factor in the range 16<br>to 31, because scaling down the current values<br>reduces the effective microstep resolution by<br>making microsteps coarser. This setting also<br>controls the maximum current value set by<br>CoolStep. |         | scaling factor<br>1/32, 2/32, 32/32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| IHOLD            | Identical to IRUN, but for motor in stand still.                                                                                                                                                                                                                                                                                                                                                                         |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| IHOLD<br>DELAY   | Allows smooth current reduction from run current<br>to hold current. <i>IHOLDDELAY</i> controls the number<br>of clock cycles for motor power down after<br><i>TZEROWAIT</i> in increments of 2^18 clocks: 0=instant<br>power down, 115: Current reduction delay per<br>current step in multiple of 2^18 clocks.                                                                                                         | 1 15    | instant IHOLD<br>1*2 <sup>18</sup> 15*2 <sup>18</sup><br>clocks per current<br>decrement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | <b>Example:</b> When using IRUN=31 and IHOLD=16, 15 current steps are required for hold current reduction. A IHOLDDELAY setting of 4 thus results in a power down time of 4*15*2^18 clock cycles, i.e. roughly one second at 16MHz.                                                                                                                                                                                      | C T     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| GLOBAL<br>SCALER | Allows fine control of the motor current range setting                                                                                                                                                                                                                                                                                                                                                                   | 0 255   | scales in 1/256 steps<br>0=full scale                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

www.trinamic.com

# **10 Velocity Based Mode Control**

The TMC5160 allows the configuration of different chopper modes and modes of operation for optimum motor control. Depending on the motor load, the different modes can be optimized for lowest noise & high precision, highest dynamics, or maximum torque at highest velocity. Some of the features like CoolStep or StallGuard2 are useful in a limited velocity range. A number of velocity thresholds allow combining the different modes of operation within an application requiring a wide velocity range.



#### Figure 10.1 Choice of velocity dependent modes

Figure 10.1 shows all available thresholds and the required ordering. VPWMTHRS, VHIGH and VCOOLTHRS are determined by the settings *TPWMTHRS*, *THIGH* and *TCOOLTHRS*. The velocity is described by the time interval *TSTEP* between each two step pulses. This allows determination of the velocity when an external step source is used. *TSTEP* always becomes normalized to 256 microstepping. This way, the thresholds do not have to be adapted when the microstep resolution is changed. The thresholds represent the same motor velocity, independent of the microstep settings. *TSTEP* becomes compared to these threshold values. A hysteresis of 1/16 *TSTEP* resp. 1/32 *TSTEP* is applied to avoid continuous toggling of the comparison results when a jitter in the *TSTEP* measurement occurs. The upper switching velocity is higher by 1/16, resp. 1/32 of the value set as threshold. The StealthChop threshold *TPWMTHRS* is not shown. It can be included with VPWMTHRS < VCOOLTHRS. The motor current can be programmed to a run and a hold level, dependent on the standstill flag *stst*.

Using automatic velocity thresholds allows tuning the application for different velocity ranges. Features like CoolStep will integrate completely transparently in your setup. This way, once parameterized, they do not require any activation or deactivation via software.

www.trinamic.com

| Parameter            | Description                                                                                                          | Setting      | Comment                                     |
|----------------------|----------------------------------------------------------------------------------------------------------------------|--------------|---------------------------------------------|
| stst                 | This flag indicates motor stand still in each operation                                                              | 0/1          | Status bit, read only                       |
| 5151                 | mode. This occurs 2 <sup>2</sup> 0 clocks after the last step pulse.                                                 | 0/1          | Status Bit, read only                       |
| TPOWER               | This is the delay time after stand still (stst) of the                                                               | 0255         | Time in multiples of 2^18                   |
| DOWN                 | motor to motor current power down. Time range                                                                        |              | t <sub>CLK</sub>                            |
|                      | is about 0 to 4 seconds.                                                                                             |              |                                             |
| TSTEP                | Actual measured time between two 1/256                                                                               | 0            | Status register, read only.                 |
|                      | microsteps derived from the step input frequency                                                                     | 1048575      | Actual measured step time                   |
|                      | in units of 1/fCLK. Measured value is (2^20)-1 in                                                                    |              | in multiple of <i>t<sub>CLK</sub></i>       |
|                      | case of overflow or stand still.                                                                                     |              | -                                           |
| TPWMTHRS             | TSTEP ≥ TPWMTHRS                                                                                                     | 0            | Setting to control the                      |
|                      | - StealthChop PWM mode is enabled, if                                                                                | 1048575      | upper velocity threshold                    |
|                      | configured                                                                                                           |              | for operation in                            |
| TCOOLTURE            | - DcStep is disabled                                                                                                 | 0            | StealthChop                                 |
| TCOOLTHRS            | <b>TCOOLTHRS</b> $\geq$ <b>TSTEP</b> $\geq$ <b>THIGH</b> :                                                           | 0<br>1048575 | Setting to control the                      |
|                      | <ul> <li>CoolStep is enabled, if configured</li> <li>StealthChop voltage PWM mode is</li> </ul>                      | 1048575      | lower velocity threshold for operation with |
|                      | <ul> <li>StealthChop voltage PWM mode is<br/>disabled</li> </ul>                                                     |              | CoolStep and StallGuard                     |
|                      | uisableu                                                                                                             |              | coolstep and stattduard                     |
|                      | TCOOLTHRS ≥ TSTEP                                                                                                    |              |                                             |
|                      | - Stop on stall and stall output signal is                                                                           |              |                                             |
|                      | enabled, if configured                                                                                               |              |                                             |
| THIGH                | TSTEP ≤ THIGH:                                                                                                       | 0            | Setting to control the                      |
|                      | - CoolStep is disabled (motor runs with                                                                              | 1048575      | upper threshold for                         |
|                      | normal current scale)                                                                                                |              | operation with CoolStep                     |
|                      | - StealthChop voltage PWM mode is                                                                                    |              | and StallGuard as well as                   |
|                      | disabled                                                                                                             |              | optional high velocity step                 |
|                      | - If <i>vhighchm</i> is set, the chopper switches                                                                    |              | mode                                        |
|                      | to chm=1 with TFD=0 (constant off time                                                                               |              |                                             |
|                      | with slow decay, only).                                                                                              |              |                                             |
|                      | - If vhighfs is set, the motor operates in                                                                           |              |                                             |
|                      | fullstep mode and the stall detection                                                                                |              |                                             |
|                      | becomes switched over to DcStep stall                                                                                |              |                                             |
|                      | detection.                                                                                                           | 0            | Illustransis is 1/1/                        |
| small_<br>bystorosis | Hysteresis for step frequency comparison based on <i>TSTEP</i> (lower velocity threshold) and                        | i            | Hysteresis is 1/16                          |
| hysteresis           | on <i>TSTEP</i> (lower velocity threshold) and ( <i>TSTEP</i> *15/16)-1 respectively ( <i>TSTEP</i> *31/32)-1 (upper | 1            | Hysteresis is 1/32                          |
|                      | velocity threshold)                                                                                                  |              |                                             |
| vhighfs              | This bit enables switching to fullstep, when VHIGH                                                                   | 0            | No switch to fullstep                       |
| Vilighijs            | is exceeded. Switching takes place only at 45°                                                                       |              |                                             |
|                      | position. The fullstep target current uses the                                                                       | 1            | Fullstep at high velocities                 |
|                      | current value from the microstep table at the 45°                                                                    | -            |                                             |
|                      | position.                                                                                                            | СТ           | RONIC                                       |
| vhighchm             | This bit enables switching to chm=1 and fd=0, when                                                                   | 0            | No change of chopper                        |
|                      | VHIGH is exceeded. This way, a higher velocity can                                                                   |              | mode                                        |
|                      | be achieved. Can be combined with <i>vhighfs</i> =1. If set,                                                         | 1            | Classic const. Toff chopper                 |
|                      | the TOFF setting automatically becomes doubled                                                                       |              | at high velocities                          |
|                      | during high velocity operation in order to avoid                                                                     |              |                                             |
| 00 014/00            | doubling of the chopper frequency.                                                                                   | 0            | No StaalthChan                              |
| en_pwm_<br>mode      | StealthChop voltage PWM enable flag (depending on velocity thresholds). Switch from off to on                        |              | No StealthChop                              |
| mode                 | state while in stand still, only.                                                                                    | 1            | StealthChop below                           |
|                      | state white in stand stitle only.                                                                                    |              | VPWMTHRS                                    |

www.trinamic.com

### **11** Diagnostics and Protection

The TMC5160 supplies a complete set of diagnostic and protection capabilities, like short circuit protection and undervoltage detection. Open load detection allows testing if a motor coil connection is interrupted. See the *DRV\_STATUS* table for details.

### **11.1** Temperature Sensors

The driver integrates a four level temperature sensor (120°C pre-warning and selectable 136°C / 143°C / 150°C thermal shutdown) for diagnostics and for protection of the IC and the power MOSFETs and adjacent components against excess heat. Choose the overtemperature level to safely cover error conditions like missing heat convection. Heat is mainly generated by the power MOSFETs, and, at increased voltage, by the internal voltage regulators. For many applications, already the overtemperature pre-warning will indicate an abnormal operation situation and can be used to initiate user warning or power reduction measures like motor current reduction. The thermal shutdown is just an emergency measure and temperature rising to the shutdown level should be prevented by design.

After triggering the overtemperature sensor (ot flag), the driver remains switched off until the system temperature falls below the pre-warning level (otpw) to avoid continuous heating to the shutdown level.

## 11.2 Short Protection

The TMC5160 protects the MOSFET power stages against a short circuit or overload condition by monitoring the voltage drop in the high-side MOSFETs, as well as the voltage drop in sense resistor and low-side MOSFETs (Figure 11.1). A programmable short detection delay (*shortdelay*) allows adjusting the detector to work with very slow switching slopes. Additionally, the short detector allows filtering of the signal. This helps to prevent spurious triggering caused by effects of PCB layout, or long, adjacent motor cables (*SHORTFILTER*). All control bits are available via register *SHORT\_CONF*. Additionally, the short detection is protected against single events, e.g. caused by ESD discharges, by retrying three times before switching off the motor continuously.

| Parameter            | Description                                                                                                                                                                                           | Setting | Comment                                                                               |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------------------------------------|
| S2VS_LEVEL           | Short or overcurrent detector level for lowside<br>FETs. Checks for voltage drop in LS MOSFET and<br>sense resistor.<br><i>Hint:</i> 6 to 8 recommended, down to 4 at low                             | 415     | 4 (highest sensitivity)<br>15 (lowest sensitivity)<br>(Reset Default:<br>OTP 6 or 12) |
|                      | current scale                                                                                                                                                                                         | 2.15    |                                                                                       |
| S2G_LEVEL            | S2G_LEVEL:<br>Short to GND detector level for highside FETs.<br>Checks for voltage drop on high side MOSFET.<br>Hint: 6 to 14 recommended (minimum 12 if the<br>bridge supply voltage can exceed 52V) | -       | 2 (highest sensitivity)<br>15 (lowest sensitivity)<br>(Reset Default:<br>OTP 6 or 12) |
| SHORT_<br>FILTER     | Spike filtering bandwidth for short detection<br><i>Hint:</i> A good PCB layout will allow using setting 0.<br>Increase value, if erroneous short detection<br>occurs.                                | 03      | 0 (lowest, 100ns),<br>1 (1μs) ( <i>Reset Default</i> ),<br>2 (2μs),<br>3 (3μs)        |
| shortdelay           | <i>shortdelay</i> : Short detection delay<br>The short detection delay shall cover the bridge<br>switching time. 0 will work for most applications.                                                   | 0/1     | 0=750ns: normal,<br>1=1500ns: high                                                    |
| CHOPCONF.<br>diss2vs | Allows to disable short to VS protection.                                                                                                                                                             | 0/1     | Leave detection enabled for normal use (0).                                           |
| CHOPCONF.<br>diss2g  | Allows to disable short to GND protection.                                                                                                                                                            | 0/1     | Leave detection enabled for normal use (0).                                           |

www.trinamic.com



Figure 11.1 Short detection

As the low-side short detection includes the sense resistor, it can be set to a high sensitivity and provides good precision of current detection. This way, it will safely cover most overcurrent conditions, i.e. when the motor stalls, or is abruptly stopped in StealthChop mode.

#### Hint

Once a short condition is safely detected, the corresponding driver bridge (A or B) becomes switched off, and the *s2ga* or *s2gb* flag, respectively *s2vsa* or *s2vsb* becomes set. To restart the motor, disable and re-enable the driver.

#### Attention

Short protection cannot protect the system and the power stages for all possible short events, as a short event is rather undefined and a complex network of external components may be involved. Therefore, short circuits should basically be avoided.

#### Hint

Set low-side short protection (S2VS) to sensitively detect an overcurrent condition (at 150 to 200% of nominal peak current). Especially with low resistive motors an overcurrent can easily be triggered by false settings, or motor stall when using StealthChop. Therefore, a sensitive short to VS setting will protect the power stage.

#### Attention

High-side short detection (S2G) sensitivity may increase at voltages of 52V and above. Therefore, a higher setting is required if motor supply voltage can overshoot up to 55V. We recommend a setting of 12 to 15 in this case. For fine tuning of overcurrent detection, trim the S2VS detector threshold. High-side short detection may falsely trigger if motor supply voltage overshoots 55V.

www.trinamic.com

### **11.3** Open Load Diagnostics

Interrupted cables are a common cause for systems failing, e.g. when connectors are not firmly plugged. The TMC5160 detects open load conditions by checking, if it can reach the desired motor coil current. This way, also undervoltage conditions, high motor velocity settings or short and overtemperature conditions may cause triggering of the open load flag, and inform the user, that motor torque may suffer. In motor stand still, open load cannot be measured, as the coils might eventually have zero current.

Open load detection is provided for system debugging.

In order to safely detect an interrupted coil connection, read out the open load flags at low or nominal motor velocity operation, only. If possible, use SpreadCycle for testing, as it provides the most accurate test. However, the *ola* and *olb* flags have just informative character and do not cause any action of the driver.



www.trinamic.com

### **12** Ramp Generator

The ramp generator allows motion based on target position or target velocity. It automatically calculates the optimum motion profile taking into account acceleration and velocity settings. The TMC5160 integrates a new type of ramp generator, which offers faster machine operation compared to the classical linear acceleration ramps. The sixPoint ramp generator allows adapting the acceleration ramps to the torque curves of a stepper motor and uses two different acceleration settings each for the acceleration phase and for the deceleration phase. See Figure 12.2.

### 12.1 Real World Unit Conversion

The TMC5160 uses its internal or external clock signal as a time reference for all internal operations. Thus, all time, velocity and acceleration settings are referenced to  $f_{CLK}$ . For best stability and reproducibility, it is recommended to use an external quartz oscillator as a time base, or to provide a clock signal from a microcontroller.

| PARAMETER VS. UNITS                     |                 |                                                                                                                                                                                |
|-----------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Param <mark>eter / S</mark> ymbol       | Unit            | calculation / description / comment                                                                                                                                            |
| f <sub>CLK</sub> [Hz]                   | [Hz]            | clock frequency of the TMC5160 in [Hz]                                                                                                                                         |
| s                                       | [s]             | second                                                                                                                                                                         |
| US                                      | µstep           |                                                                                                                                                                                |
| FS                                      | fullstep        |                                                                                                                                                                                |
| µstep velocity v[Hz]                    | µsteps / s      | v[Hz] = v[5160] * ( f <sub>cLK</sub> [Hz]/2 / 2^23 )                                                                                                                           |
| µstep acceleration a[Hz/s]              | µsteps / s^2    | a[Hz/s] = a[5160] * f <sub>CLK</sub> [Hz]^2 / (512*256) / 2^24                                                                                                                 |
| USC microstep count                     | counts          | microstep resolution in number of microsteps<br>(i.e. the number of microsteps between two<br>fullsteps – normally 256)                                                        |
| rotations per second v[rps]             | rotations / s   | v[rps] = v[µsteps/s] / USC / FSC<br>FSC: motor fullsteps per rotation, e.g. 200                                                                                                |
| rps acceleration a[rps/s <sup>2</sup> ] | rotations / s^2 | a[rps/s <sup>2</sup> ] = a[µsteps/s <sup>2</sup> ] / USC / FSC                                                                                                                 |
| ramp steps[µsteps] = rs                 | µsteps          | rs = (v[5160]) <sup>2</sup> / a[5160] / 2 <sup>8</sup><br>microsteps during linear acceleration ramp<br>(assuming acceleration from 0 to v)                                    |
| TSTEP, TTHRS                            |                 | TSTEP = $f_{CLK} / f_{STEP}$<br>The time reference for velocity thresholds is<br>referred to the actual microstep frequency of<br>the clock input respectively velocity v[Hz]. |

The units of a TMC5160 register content are written as register[5160].

In rare cases, the upper acceleration limit might impose a limitation to the application, e.g. when working with a reduced clock frequency or high gearing and low load on the motor. In order to increase the effective acceleration possible, the microstep resolution of the sequencer input may be decreased. Setting the *CHOPCONF* options *intpol*=1 and *MRES*=%0001 will double the motor velocity for the same speed setting and thus also double effective acceleration and deceleration. The motor will have the same smoothness, but half position resolution with this setting.

#### Quick Start

For a quick start, see the Quick Configuration Guide in chapter 22.

www.trinamic.com

### **12.2** Motion Profiles

For the ramp generator register set, please refer to the chapter 6.3.

### 12.2.1 Ramp Mode

The ramp generator delivers two phase acceleration and two phase deceleration ramps with additional programmable start and stop velocities (see Figure 12.1).

#### Note

The start velocity can be set to zero, if not used.

The stop velocity can be set to ten (or down to one), if not used.

Take care to set *VSTOP* identical to or above *VSTART*. This ensures that even a short motion can be terminated successfully at the target position.

The two different sets of acceleration and deceleration can be combined freely. A common transition speed V1 allows for velocity dependent switching between both acceleration and deceleration settings. A typical use case will use lower acceleration and deceleration values at higher velocities, as the motors torque declines at higher velocity. When considering friction in the system, it becomes clear, that typically deceleration of the system is quicker than acceleration. Thus, deceleration values can be higher in many applications. This way, operation speed of the motor in time critical applications can be maximized.

As target positions and ramp parameters may be changed any time during the motion, the motion controller will always use the optimum (fastest) way to reach the target, while sticking to the constraints set by the user. This way it might happen, that the motion becomes automatically stopped, crosses zero and drives back again. This case is flagged by the special flag second\_move.

### 12.2.2 Start and Stop Velocity

When using increased levels of start- and stop velocity, it becomes clear, that a subsequent move into the opposite direction would provide a jerk identical to VSTART+VSTOP, rather than only VSTART. As the motor probably is not able to follow this, you can set a time delay for a subsequent move by setting TZEROWAIT. An active delay time is flagged by the flag t\_zerowait\_active. Once the target position is reached, the flag position\_reached becomes active.





www.trinamic.com





### 12.2.3 Velocity Mode

For the ease of use, velocity mode movements do not use the different acceleration and deceleration settings. You need to set VMAX and AMAX only for velocity mode. The ramp generator always uses AMAX to accelerate or decelerate to VMAX in this mode.

In order to decelerate the motor to stand still, it is sufficient to set VMAX to zero. The flag vzero signals standstill of the motor. The flag velocity\_reached always signals, that the target velocity has been reached.

### 12.2.4 Early Ramp Termination

In cases where users can interact with a system, some applications require terminating a motion by ramping down to zero velocity before the target position has been reached.

**OPTIONS TO TERMINATE MOTION USING ACCELERATION SETTINGS:** 

- a) Switch to velocity mode, set VMAX=0 and AMAX to the desired deceleration value. This will stop the motor using a linear ramp.
- b) For a stop in positioning mode, set VSTART=0 and VMAX=0. VSTOP is not used in this case. The driver will use AMAX and A1 (as determined by V1) for going to zero velocity.
- c) For a stop using D1, DMAX and VSTOP, trigger the deceleration phase by copying XACTUAL to XTARGET. Set TZEROWAIT sufficiently to allow the CPU to interact during this time. The driver will decelerate and eventually come to a stop. Poll the actual velocity to terminate motion during TZEROWAIT time using option a) or b).
- d) Activate a stop switch. This can be done by means of the hardware input, e.g. using a wired 'OR' to the stop switch input. If you do not use the hardware input and have tied the REFL and REFR to a fixed level, enable the stop function (stop\_l\_enable, stop\_r\_enable) and use the inverting function (pol\_stop\_l, pol\_stop\_r) to simulate the switch activation.

#### www.trinamic.com

### 12.2.5 Application Example: Joystick Control

Applications like surveillance cameras can be optimally enhanced using the motion controller: while joystick commands operate the motor at a user defined velocity, the target ramp generator ensures that the valid motion range never is left.

#### **REALIZE JOYSTICK CONTROL**

- 1. Use positioning mode in order to control the motion direction and to set the motion limit(s).
- 2. Modify VMAX at any time in the range VSTART to your maximum value. With VSTART=0, you can also stop motion by setting VMAX=0. The motion controller will use A1 and AMAX as determined by V1 to adapt velocity for ramping up and ramping down.
- 3. In case you do not modify the acceleration settings, you do not need to rewrite XTARGET, just modify VMAX.
- 4. DMAX, D1 and VSTOP only become used when the ramp controller slows down due to reaching the target position, or when the target position has been modified to point to the other direction.

## 12.3 Velocity Thresholds

The ramp generator provides a number of velocity thresholds coupled with the actual velocity VACTUAL. The different ranges allow programming the motor to the optimum step mode, coil current and acceleration settings. Most applications will not require all of the thresholds, but in principle all modes can be combined as shown in Figure 12.1. VHIGH and VCOOLTHRS are determined by the settings *THIGH* and *TCOOLTHRS* in order to allow determination of the velocity when an external step source is used. *TSTEP* becomes compared to these threshold values. A hysteresis of 1/16 *TSTEP* resp. 1/32 *TSTEP* is applied to avoid continuous toggling of the comparison results when a jitter in the *TSTEP* measurement occurs. The upper switching velocity is higher by 1/16, resp. 1/32 of the value set as threshold. The StealthChop threshold *TPWMTHRS* is not shown. It can be included with VPWMTHRS < VCOOLTHRS.



#### Figure 12.3 Ramp generator velocity dependent motor control

The velocity thresholds for the different chopper modes and sensorless operation features are coupled to the time between each two microsteps *TSTEP*.

www.trinamic.com

### 12.4 Reference Switches

Prior to normal operation of the drive an absolute reference position must be set. The reference position can be found using a mechanical stop which can be detected by stall detection, or by a reference switch.

In case of a linear drive, the mechanical motion range must not be left. This can be ensured also for abnormal situations by enabling the stop switch functions for the left and the right reference switch. Therefore, the ramp generator responds to a number of stop events as configured in the SW\_MODE register. There are two ways to stop the motor:

- It can be stopped abruptly, when a switch is hit. This is useful in an emergency case and for StallGuard based homing.
- Or the motor can be softly decelerated to zero using deceleration settings (DMAX, V1, D1).

Hint Latching of the ramp position XACTUAL to the holding register XLATCH upon a switch event gives a precise snapshot of the position of the reference switch. +VCC\_IO +VCC\_IO 10k 10k REFL REFR 22k Motor 1nF Negative Positive direction direction Optional RC filter Traveler (example)

#### Figure 12.4 Using reference switches (example)

Normally open or normally closed switches can be used by programming the switch polarity or selecting the pullup or pull-down resistor configuration. A normally closed switch is failsafe with respect to an interrupt of the switch connection. Switches which can be used are:

- mechanical switches,
- photo interrupters, or
- hall sensors.

Be careful to select reference switch resistors matching your switch requirements! In case of long cables additional RC filtering might be required near the TMC5160 reference inputs. Adding an RC filter will also reduce the danger of destroying the logic level inputs by wiring faults, but it will add a certain delay which should be considered with respect to the application.

#### IMPLEMENTING A HOMING PROCEDURE

- 1. Make sure, that the home switch is not pressed, e.g. by moving away from the switch.
- 2. Activate position latching upon the desired switch event and activate motor (soft) stop upon active switch. StallGuard based homing requires using a hard stop (en\_softstop=0).
- 3. Start a motion ramp into the direction of the switch. (Move to a more negative position for a left switch, to a more positive position for a right switch). You may timeout this motion by using a position ramping command.

www.trinamic.com

- 4. As soon as the switch is hit, the position becomes latched and the motor is stopped. Wait until the motor is in standstill again by polling the actual velocity *VACTUAL* or checking *vzero* or the *standstill* flag.
- 5. Switch the ramp generator to hold mode and calculate the difference between the latched position and the actual position. For StallGuard based homing or when using hard stop, *XACTUAL* stops exactly at the home position, so there is no difference (0).
- 6. Write the calculated difference into the actual position register. Now, homing is finished. A move to position 0 will bring back the motor exactly to the switching point. In case StallGuard was used for homing, read and write back *RAMP\_STAT* to clear the StallGuard stop event *event\_stop\_sg* and release the motor from the stop condition.

#### Homing with a Third Switch

Some applications use an additional home switch, which operates independently of the mechanical limit switches. The encoder functionality of the TMC5160 provides an additional source for position latching. It allows using the N channel input to snapshot *XACTUAL* with a rising or falling edge event, or both. This function also provides an interrupt output.

- 1. Activate the latching function (ENCMODE: Set ignoreAB, clr\_cont, neg\_edge or pos\_edge and latch\_x\_act). The latching function can then trigger the interrupt output (check by reading n\_event in ENC\_STATUS when interrupt is signaled at DIAGO).
- 2. Move to the direction, where the N channel switch should be. In case the motor hits a stop switch (REFL or REFR) before the home switch is detected, reverse the motion direction.
- 3. Read out XLATCH once the switch has been triggered. It gives the position of the switch event.
- 4. After detection of the switch event, stop the motor, and subtract XLATCH from the actual position. Read and write back ENC\_STAT to clear the status flags. (A detailed description of the required steps is in the homing procedure above.)

ELECTRO

### 13 StallGuard2 Load Measurement

StallGuard2 provides an accurate measurement of the load on the motor. It can be used for stall detection as well as other uses at loads below those which stall the motor, such as CoolStep load-adaptive current reduction. The StallGuard2 measurement value changes linearly over a wide range of load, velocity, and current settings, as shown in Figure 13.1. At maximum motor load, the value goes to zero or near to zero. This corresponds to a load angle of 90° between the magnetic field of the coils and magnets in the rotor. This also is the most energy-efficient point of operation for the motor.



Figure 13.1 Function principle of StallGuard2

| Parameter   | Description                                                                                                                                                                                                                                                                    | Setting | Comment                                                          |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------------------------------------------------------|
| SGT         | This signed value controls the StallGuard2                                                                                                                                                                                                                                     | 0       | indifferent value                                                |
|             | threshold level for stall detection and sets the optimum measurement range for readout. A                                                                                                                                                                                      | +1 +63  | less sensitivity<br>higher sensitivity                           |
|             | lower value gives a higher sensitivity. Zero is the starting value working with most motors. A                                                                                                                                                                                 | -104    | inglier sensitivity                                              |
|             | higher value makes StallGuard2 less sensitive and requires more torgue to indicate a stall.                                                                                                                                                                                    |         |                                                                  |
| sfilt       | Enables the StallGuard2 filter for more precision                                                                                                                                                                                                                              | 0       | standard mode                                                    |
|             | of the measurement. If set, reduces the                                                                                                                                                                                                                                        | 1       | filtered mode                                                    |
|             | measurement frequency to one measurement per electrical period of the motor (4 fullsteps).                                                                                                                                                                                     |         |                                                                  |
| Status word | Description                                                                                                                                                                                                                                                                    | Range   | Comment                                                          |
| SG_RESULT   | This is the StallGuard2 result. A higher reading<br>indicates less mechanical load. A lower reading<br>indicates a higher load and thus a higher load<br>angle. Tune the SGT setting to show a SG_RESULT<br>reading of roughly 0 to 100 at maximum load<br>before motor stall. |         | 0: highest load<br>low value: high load<br>high value: less load |

#### Hint

In order to use StallGuard2 and CoolStep, the StallGuard2 sensitivity should first be tuned using the SGT setting!

www.trinamic.com

### 13.1 Tuning StallGuard2 Threshold SGT

The StallGuard2 value *SG\_RESULT* is affected by motor-specific characteristics and application-specific demands on load and velocity. Therefore the easiest way to tune the StallGuard2 threshold *SGT* for a specific motor type and operating conditions is interactive tuning in the actual application.

#### INITIAL PROCEDURE FOR TUNING STALLGUARD SGT

- 1. Operate the motor at the normal operation velocity for your application and monitor SG\_RESULT.
- 2. Apply slowly increasing mechanical load to the motor. If the motor stalls before SG\_RESULT reaches zero, decrease SGT. If SG\_RESULT reaches zero before the motor stalls, increase SGT. A good SGT starting value is zero. SGT is signed, so it can have negative or positive values.
- 3. Set *TCOOLTHRS* to a value above *TSTEP* and enable *sg\_stop* to enable the stop on stall feature. Make sure, that the motor is safely stopped whenever it is stalled. Increase *SGT* if the motor becomes stopped before a stall occurs. Restart the motor by disabling *sg\_stop* or by reading and writing back the *RAMP\_STAT* register (write+clear function).
- 4. The optimum setting is reached when SG\_RESULT is between 0 and roughly 100 at increasing load shortly before the motor stalls, and SG\_RESULT increases by 100 or more without load. SGT in most cases can be tuned for a certain motion velocity or a velocity range. Make sure, that the setting works reliable in a certain range (e.g. 80% to 120% of desired velocity) and also under extreme motor conditions (lowest and highest applicable temperature).

#### **OPTIONAL PROCEDURE ALLOWING AUTOMATIC TUNING OF SGT**

The basic idea behind the SGT setting is a factor, which compensates the StallGuard measurement for resistive losses inside the motor. At standstill and very low velocities, resistive losses are the main factor for the balance of energy in the motor, because mechanical power is zero or near to zero. This way, SGT can be set to an optimum at near zero velocity. This algorithm is especially useful for tuning SGT within the application to give the best result independent of environment conditions, motor stray, etc.

- Operate the motor at low velocity < 10 RPM (i.e. a few to a few fullsteps per second) and target operation current and supply voltage. In this velocity range, there is not much dependence of SG\_RESULT on the motor load, because the motor does not generate significant back EMF. Therefore, mechanical load will not make a big difference on the result.
- 2. Switch on *sfilt*. Now increase *SGT* starting from 0 to a value, where *SG\_RESULT* starts rising. With a high *SGT*, *SG\_RESULT* will rise up to the maximum value. Reduce again to the highest value, where *SG\_RESULT* stays at 0. Now the *SGT* value is set as sensibly as possible. When you see *SG\_RESULT* increasing at higher velocities, there will be useful stall detection.

The upper velocity for the stall detection with this setting is determined by the velocity, where the motor back EMF approaches the supply voltage and the motor current starts dropping when further increasing velocity.

SG\_RESULT goes to zero when the motor stalls and the ramp generator can be programmed to stop the motor upon a stall event by enabling sg\_stop in SW\_MODE. Set TCOOLTHRS to match the lower velocity threshold where StallGuard delivers a good result in order to use sg\_stop.

The power supply voltage also affects *SG\_RESULT*, so tighter voltage regulation results in more accurate values. StallGuard measurement has a high resolution, and there are a few ways to enhance its accuracy, as described in the following sections.

#### Quick Start

For a quick start, see the Quick Configuration Guide in chapter 22. For detail procedure see Application Note AN002 - Parameterization of StallGuard2 & CoolStep

www.trinamic.com

### 13.1.1 Variable Velocity Limits TCOOLTHRS and THIGH

The *SGT* setting chosen as a result of the previously described *SGT* tuning can be used for a certain velocity range. Outside this range, a stall may not be detected safely, and CoolStep might not give the optimum result.



Figure 13.2 Example: optimum SGT setting and StallGuard2 reading with an example motor

In many applications, operation at or near a single operation point is used most of the time and a single setting is sufficient. The driver provides a lower and an upper velocity threshold to match this. The stall detection is disabled outside the determined operation point, e.g. during acceleration phases preceding a sensorless homing procedure when setting *TCOOLTHRS* to a matching value. An upper limit can be specified by *THIGH*.

In some applications, a velocity dependent tuning of the *SGT* value can be expedient, using a small number of support points and linear interpolation.

### 13.1.2 Small Motors with High Torque Ripple and Resonance

Motors with a high detent torque show an increased variation of the StallGuard2 measurement value SG with varying motor currents, especially at low currents. For these motors, the current dependency should be checked for best result.

### 13.1.3 Temperature Dependence of Motor Coil Resistance

Motors working over a wide temperature range may require temperature correction, because motor coil resistance increases with rising temperature. This can be corrected as a linear reduction of *SGT* at increasing temperature, as motor efficiency is reduced.

### 13.1.4 Accuracy and Reproducibility of StallGuard2 Measurement

In a production environment, it may be desirable to use a fixed *SGT* value within an application for one motor type. Most of the unit-to-unit variation in StallGuard2 measurements results from manufacturing tolerances in motor construction. The measurement error of StallGuard2 – provided that all other parameters remain stable – can be as low as:

stallGuard measurement error =  $\pm max(1, |SGT|)$ 

www.trinamic.com

### 13.2 StallGuard2 Update Rate and Filter

The StallGuard2 measurement value *SG\_RESULT* is updated with each full step of the motor. This is enough to safely detect a stall, because a stall always means the loss of four full steps. In a practical application, especially when using CoolStep, a more precise measurement might be more important than an update for each fullstep because the mechanical load never changes instantaneously from one step to the next. For these applications, the *sfilt* bit enables a filtering function over four load measurements. The filter should always be enabled when high-precision measurement is required. It compensates for variations in motor construction, for example due to misalignment of the phase A to phase B magnets. The filter should be disabled when rapid response to increasing load is required and for best results of sensorless homing using StallGuard.

### 13.3 Detecting a Motor Stall

For best stall detection, work without StallGuard filtering (*sfilt=*0). To safely detect a motor stall the stall threshold must be determined using a specific *SGT* setting. Therefore, the maximum load needs to be determined, which the motor can drive without stalling. At the same time, monitor the *SG\_RESULT* value at this load, e.g. some value within the range 0 to 100. The stall threshold should be a value safely within the operating limits, to allow for parameter stray. The response at an *SGT* setting at or near 0 gives some idea on the quality of the signal: Check the *SG* value without load and with maximum load. They should show a difference of at least 100 or a few 100, which shall be large compared to the offset. If you set the *SGT* value in a way, that a reading of 0 occurs at maximum motor load, the stall can be automatically detected by the motion controller to issue a motor stop. In the moment of the step resulting in a step loss, the lowest reading will be visible. After the step loss, the motor will vibrate and show a higher *SG\_RESULT* reading.

### 13.4 Homing with StallGuard

The homing of a linear drive requires moving the motor into the direction of a hard stop. As StallGuard needs a certain velocity to work (as set by *TCOOLTHRS*), make sure that the start point is far enough away from the hard stop to provide the distance required for the acceleration phase. After setting up *SGT* and the ramp generator registers, start a motion into the direction of the hard stop and activate the stop on stall function (set *sg\_stop* in *SW\_MODE*). Once a stall is detected, the ramp generator stops motion and sets *VACTUAL* zero, stopping the motor. The stop condition also is indicated by the flag *StallGuard* in *DRV\_STATUS*. After setting up new motion parameters in order to prevent the motor from restarting right away, StallGuard can be disabled, or the motor can be reenabled by reading and writing back *RAMP\_STAT*. The write and clear function of the *event\_stop\_sg* flag in *RAMP\_STAT* restarts the motor after expiration of *TZEROWAIT* in case the motion parameters have not been modified. Best results are yielded at 30% to 70% of nominal motor current and typically 1 to 5 RPS (motors smaller than NEMA17 may require higher velocities).

### 13.5 Limits of StallGuard2 Operation

StallGuard2 does not operate reliably at extreme motor velocities: Very low motor velocities (for many motors, less than one revolution per second) generate a low back EMF and make the measurement unstable and dependent on environment conditions (temperature, etc.). The automatic tuning procedure described above will compensate for this. Other conditions will also lead to extreme settings of *SGT* and poor response of the measurement value *SG\_RESULT* to the motor load.

Very high motor velocities, in which the full sinusoidal current is not driven into the motor coils also leads to poor response. These velocities are typically characterized by the motor back EMF reaching the supply voltage.

www.trinamic.com

# 14 CoolStep Operation

CoolStep is an automatic smart energy optimization for stepper motors based on the motor mechanical load, making them "green".

# 14.1 User Benefits



Energy efficiency Motor generates less heat Less cooling infrastructure Cheaper motor

- consumption decreased up to 75%
- improved mechanical precision
- for motor and driver
- does the job!

CoolStep allows substantial energy savings, especially for motors which see varying loads or operate at a high duty cycle. Because a stepper motor application needs to work with a torque reserve of 30% to 50%, even a constant-load application allows significant energy savings because CoolStep automatically enables torque reserve when required. Reducing power consumption keeps the system cooler, increases motor life, and allows reducing cost in the power supply and cooling components.

Reducing motor current by half results in reducing power by a factor of four.

# 14.2 Setting up for CoolStep

CoolStep is controlled by several parameters, but two are critical for understanding how it works:

| Parameter | Description                                                                                   | Range | Comment               |
|-----------|-----------------------------------------------------------------------------------------------|-------|-----------------------|
| SEMIN     | 4-bit unsigned integer that sets a lower threshold.                                           | 1000  | disable CoolStep      |
|           | If SG goes below this threshold, CoolStep                                                     |       | threshold is SEMIN*32 |
|           | increases the current to both coils. The 4-bit SEMIN value is scaled by 32 to cover the lower |       |                       |
|           | half of the range of the 10-bit SG value. (The                                                |       |                       |
|           | name of this parameter is derived from                                                        |       |                       |
|           | sma <mark>rtEn</mark> ergy, which is an earlier name for CoolStep.)                           |       |                       |
| SEMAX     | 4-bit unsigned integer that controls an upper                                                 | 015   | threshold is          |
|           | threshold. If SG is sampled equal to or above this                                            |       | (SEMIN+SEMAX+1)*32    |
|           | threshold enough times, CoolStep decreases the                                                |       |                       |
|           | current to both coils. The upper threshold is                                                 |       |                       |
|           | (SEMIN + SEMAX + 1)*32.                                                                       |       |                       |
|           |                                                                                               |       |                       |

Figure 14.1 shows the operating regions of CoolStep:

- The black line represents the SG measurement value.
- The blue line represents the mechanical load applied to the motor.
- The red line represents the current into the motor coils.

When the load increases,  $SG_RESULT$  falls below SEMIN, and CoolStep increases the current. When the load decreases,  $SG_RESULT$  rises above (SEMIN + SEMAX + 1) \* 32, and the current is reduced.

www.trinamic.com



#### Figure 14.1 CoolStep adapts motor current to the load

Five more parameters control CoolStep and one status value is returned:

| Parameter              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Range  | Comment                                                                                                                                                                 |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SEUP                   | Sets the <i>current increment step</i> . The current becomes incremented for each measured StallGuard2 value below the lower threshold.                                                                                                                                                                                                                                                                                                                                                                                                                                               | 03     | step width is<br>1, 2, 4, 8                                                                                                                                             |
| SEDN                   | Sets the number of StallGuard2 readings above<br>the upper threshold necessary for each current<br>decrement of the motor current.                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 03     | number of StallGuard2<br>measurements per<br>decrement:<br>32, 8, 2, 1                                                                                                  |
| SEIMIN                 | Sets the <i>lower motor current limit</i> for CoolStep operation by scaling the <i>IRUN</i> current setting.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0      | 0: 1/2 of IRUN<br>1: 1/4 of IRUN                                                                                                                                        |
| TCOOL<br>THRS<br>THIGH | Lower velocity threshold for switching on<br>CoolStep and stop on stall. Below this velocity<br>CoolStep becomes disabled (not used in STEP/DIR<br>mode). Adapt to the lower limit of the velocity<br>range where StallGuard2 gives a stable result.<br><i>Hint:</i> May be adapted to disable CoolStep during<br>acceleration and deceleration phase by setting<br>identical to VMAX.<br>Upper velocity threshold value for CoolStep and<br>stop on stall. Above this velocity CoolStep<br>becomes disabled. Adapt to the velocity range<br>where StallGuard2 gives a stable result. | 2^20-1 | Specifies lower CoolStep<br>velocity by comparing<br>the threshold value to<br><i>TSTEP</i><br>Also controls additional<br>functions like switching<br>to fullstepping. |
| Status<br>word         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Range  | Comment                                                                                                                                                                 |
| CSACTUAL               | This status value provides the <i>actual motor current scale</i> as controlled by CoolStep. The value goes up to the <i>IRUN</i> value and down to the portion of <i>IRUN</i> as specified by <i>SEIMIN</i> .                                                                                                                                                                                                                                                                                                                                                                         | 031    | 1/32, 2/32, 32/32                                                                                                                                                       |

www.trinamic.com

### 14.3 Tuning CoolStep

Before tuning CoolStep, first tune the StallGuard2 threshold level SGT, which affects the range of the load measurement value  $SG\_RESULT$ . CoolStep uses  $SG\_RESULT$  to operate the motor near the optimum load angle of +90°.

The current increment speed is specified in *SEUP*, and the current decrement speed is specified in *SEDN*. They can be tuned separately because they are triggered by different events that may need different responses. The encodings for these parameters allow the coil currents to be increased much more quickly than decreased, because crossing the lower threshold is a more serious event that may require a faster response. If the response is too slow, the motor may stall. In contrast, a slow response to crossing the upper threshold does not risk anything more serious than missing an opportunity to save power.

CoolStep operates between limits controlled by the current scale parameter IRUN and the seimin bit.

### 14.3.1 Response Time

For fast response to increasing motor load, use a high current increment step *SEUP*. If the motor load changes slowly, a lower current increment step can be used to avoid motor oscillations. If the filter controlled by *sfilt* is enabled, the measurement rate and regulation speed are cut by a factor of four.

Hint

The most common and most beneficial use is to adapt CoolStep for operation at the typical system target operation velocity and to set the velocity thresholds according. As acceleration and decelerations normally shall be quick, they will require the full motor current, while they have only a small contribution to overall power consumption due to their short duration.

### 14.3.2 Low Velocity and Standby Operation

Because CoolStep is not able to measure the motor load in standstill and at very low RPM, a lower velocity threshold is provided in the ramp generator. It should be set to an application specific default value. Below this threshold the normal current setting via *IRUN* respectively *IHOLD* is valid. An upper threshold is provided by the *VHIGH* setting. Both thresholds can be set as a result of the StallGuard2 tuning process.



www.trinamic.com

# **15** STEP/DIR Interface

The STEP and DIR inputs provide a simple, standard interface compatible with many existing motion controllers. The MicroPlyer STEP pulse interpolator brings the smooth motor operation of high-resolution microstepping to applications originally designed for coarser stepping. In case an external step source is used, the complete integrated motion controller can be switched off. The only motion controller registers remaining active in this case are the current settings in register *IHOLD\_IRUN*.

### 15.1 Timing

Figure 15.1 shows the timing parameters for the STEP and DIR signals, and the table below gives their specifications. When the *dedge* mode bit in the *CHOPCONF* register is set, both edges of STEP are active. If *dedge* is cleared, only rising edges are active. STEP and DIR are sampled and synchronized to the system clock. An internal analog filter removes glitches on the signals, such as those caused by long PCB traces. If the signal source is far from the chip, and especially if the signals are carried on cables, the signals should be filtered or differentially transmitted.



Figure 15.1 STEP and DIR timing, Input pin filter

| STEP and DIR interface timing                      | AC-Characteristics<br>clock period is t <sub>CLK</sub> |                                    |                                                    |                     |                       |      |
|----------------------------------------------------|--------------------------------------------------------|------------------------------------|----------------------------------------------------|---------------------|-----------------------|------|
| Parameter                                          | Symbol                                                 | Conditions                         | Min                                                | Тур                 | Max                   | Unit |
| step frequency (at maximum                         | <b>f</b> <sub>STEP</sub>                               | dedge=0                            |                                                    |                     | 1∕2 f <sub>CLK</sub>  |      |
| microstep resolution)                              |                                                        | dedge=1                            |                                                    |                     | <b>1∕4 f</b> сlк      |      |
| fullstep frequency                                 | f <sub>FS</sub>                                        |                                    |                                                    |                     | f <sub>ськ</sub> /512 |      |
| STEP input low time *)                             | t <sub>SL</sub>                                        |                                    | max(tfiltsd,<br>t <sub>CLK</sub> +20)              | 100                 |                       | ns   |
| STEP input high time *)                            | t <sub>SH</sub>                                        | ELEC                               | max(t <sub>FILTSD</sub> ,<br>t <sub>CLK</sub> +20) | 100                 | IC                    | ns   |
| DIR to STEP setup time                             | t <sub>DSU</sub>                                       |                                    | 20                                                 |                     |                       | ns   |
| DIR after STEP hold time                           | t <sub>DSH</sub>                                       |                                    | 20                                                 |                     |                       | ns   |
| STEP and DIR spike filtering time                  | t <sub>FILTSD</sub>                                    | rising and falling                 | 13                                                 | 20                  | 30                    | ns   |
| *)                                                 |                                                        | edge                               |                                                    |                     |                       |      |
| STEP and DIR sampling relative to rising CLK input | t <sub>sdclkhi</sub>                                   | before rising edge<br>of CLK input |                                                    | t <sub>FILTSD</sub> |                       | ns   |

\*) These values are valid with full input logic level swing, only. Asymmetric logic levels will increase filtering delay t<sub>FILTSD</sub>, due to an internal input RC filter.

94

# published by WWW.SKYTECH.IR

www.trinamic.com

### **15.2** Changing Resolution

The TMC5160 includes an internal microstep table with 1024 sine wave entries to generate sinusoidal motor coil currents. These 1024 entries correspond to one electrical revolution or four fullsteps. The microstep resolution setting determines the step width taken within the table. Depending on the DIR input, the microstep counter is increased (DIR=0) or decreased (DIR=1) with each STEP pulse by the step width. The microstep resolution determines the increment respectively the decrement. At maximum resolution, the sequencer advances one step for each step pulse. At half resolution, it advances two steps. Increment is up to 256 steps for fullstepping. The sequencer has special provision to allow seamless switching between different microstep rates at any time. When switching to a lower microstep resolution, it calculates the nearest step within the target resolution and reads the current vector at that position. This behavior especially is important for low resolutions like fullstep and halfstep, because any failure in the step sequence would lead to asymmetrical run when comparing a motor running clockwise and counterclockwise.

| Ехам  | PLES:   |                                                                                                                                                                                                                                                                |
|-------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fulls | tep:    | Cycles through table positions: 128, 384, 640 and 896 (45°, 135°, 225° and 315° electrical position, both coils on at identical current). The coil current in each position corresponds to the RMS-Value (0.71 * amplitude). Step size is 256 (90° electrical) |
| Half  | step:   | The first table position is 64 (22.5° electrical), Step size is 128 (45° steps)                                                                                                                                                                                |
| Quai  | ter ste | p: The first table position is 32 (90°/8=11.25° electrical), Step size is 64 (22.5° steps)                                                                                                                                                                     |

This way equidistant steps result and they are identical in both rotation directions. Some older drivers also use zero current (table entry 0, 0°) as well as full current (90°) within the step tables. This kind of stepping is avoided because it provides less torque and has a worse power dissipation in driver and motor.

| Step position | table position | current coil A | current coil B |
|---------------|----------------|----------------|----------------|
| Half step 0   | 64             | 38.3%          | 92.4%          |
| Full step 0   | 128            | 70.7%          | 70.7%          |
| Half step 1   | 192            | 92.4%          | 38.3%          |
| Half step 2   | 320            | 92.4%          | -38.3%         |
| Full step 1   | 384            | 70.7%          | -70.7%         |
| Half step 3   | 448            | 38.3%          | -92.4%         |
| Half step 4   | 576            | -38.3%         | -92.4%         |
| Full step 2   | 640            | -70.7%         | -70.7%         |
| Half step 5   | 704            | -92.4%         | -38.3%         |
| Half step 6   | 832            | -92.4%         | 38.3%          |
| Full step 3   | 896            | -70.7%         | 70.7%          |
| Half step 7   | 960            | -38.3%         | 92.4%          |
|               |                |                |                |

www.trinamic.com

### **15.3 MicroPlyer and Stand Still Detection**

For each active edge on STEP, MicroPlyer produces microsteps at 256x resolution, as shown in Figure 15.2. It interpolates the time in between of two step impulses at the step input based on the last step interval. This way, from 2 microsteps (128 microstep to 256 microstep interpolation) up to 256 microsteps (full step input to 256 microsteps) are driven for a single step pulse.

Enable MicroPlyer by setting the *intpol* bit in the *CHOPCONF* register. *GCONF.faststandstill* allows reduction of standstill detection time to 2<sup>18</sup> clocks (-20ms)

The step rate for the interpolated 2 to 256 microsteps is determined by measuring the time interval of the previous step period and dividing it into up to 256 equal parts. The maximum time between two microsteps corresponds to  $2^{20}$  (roughly one million system clock cycles), for an even distribution of 256 microsteps. At 12 MHz system clock frequency, this results in a minimum step input frequency of 12 Hz for MicroPlyer operation (50 Hz with *faststandstill* = 1). A lower step rate causes the *STST* bit to be set, which indicates a standstill event. At that frequency, microsteps occur at a rate of (system clock frequency)/ $2^{16}$  - 256 Hz. When a stand still is detected, the driver automatically switches the motor to holding current *IHOLD*.

#### Hint

MicroPlyer only works perfectly with a stable STEP frequency. Do not use the *dedge* option if the STEP signal does not have a 50% duty cycle.



#### Figure 15.2 MicroPlyer microstep interpolation with rising STEP frequency (Example: 16 to 256)

In Figure 15.2, the first STEP cycle is long enough to set the standstill bit *stst*. This bit is cleared on the next STEP active edge. Then, the external STEP frequency increases. After one cycle at the higher rate MicroPlyer adapts the interpolated microstep rate to the higher frequency. During the last cycle at the slower rate, MicroPlyer did not generate all 16 microsteps, so there is a small jump in motor angle between the first and second cycles at the higher rate. With the flag *GCONF.faststandstill* enabled, standstill detection is after 2^18 clocks (rather than 2^20 clocks) without step pulse. This allows faster current reduction for energy saving in drives with short stand still times.

#### www.trinamic.com

# **16 DIAG Outputs**

### 16.1 STEP/DIR Mode

Operation with an external motion controller often requires quick reaction to certain states of the stepper motor driver. Therefore, the DIAG outputs supply a configurable set of different real time information complementing the STEP/DIR interface.

Both, the information available at DIAGO and DIAG1 can be selected as well as the type of output (low active open drain – default setting, or high active push-pull). In order to determine a reset of the driver, DIAGO always shows a power-on reset condition by pulling low during a reset condition. Figure 16.1 shows the available signals and control bits.



#### Figure 16.1 DIAG outputs in STEP/DIR mode

The stall output signal allows StallGuard2 to be handled by the external motion controller like a stop switch. The index output signals the microstep counter zero position, to allow the application to reference the drive to a certain current pattern. Chopper on-state shows the on-state of both coil choppers (alternating) when working in SpreadCycle or constant off time in order to determine the duty cycle. The DcStep skipped information is an alternative way to find out when DcStep runs with a velocity below the step velocity. It toggles with each step not taken by the sequencer.

#### Attention

The duration of the index pulse corresponds to the duration of the microstep. When working without interpolation at less than 256 microsteps, the index time goes down to two CLK clock cycles.

In motion controller mode, the DIAG outputs deliver a position compare signal to allow exact triggering of external logic, and an interrupt signal in order to trigger software to certain conditions within the motion ramp. Either an open drain (active low) output signal can be chosen (default), or an active high push-pull output signal. When using the open drain output, an external pull up resistor in the range  $4.7k\Omega$  to  $33k\Omega$  is required. DIAGO also becomes driven low upon a reset condition. However

www.trinamic.com

### **16.2 Motion Controller Mode** In motion controller mode, the DIAG outputs deliver a position comp triggering of external logic, and an interrupt signal in order to trigger sof within the motion ramp. Fither an open drain (active low) output signal as

the end of the reset condition cannot be determined by monitoring DIAG0 in this configuration, because *event\_pos\_reached* flag also becomes active upon reset and thus the pin stays actively low after the reset condition. In order to safely determine a reset condition, monitor the *reset* flag by SPI or read out any register to confirm that the chip is powered up.



www.trinamic.com

## 17 DcStep

DcStep is an automatic commutation mode for the stepper motor. It allows the stepper to run with its target velocity as commanded by the ramp generator as long as it can cope with the load. In case the motor becomes overloaded, it slows down to a velocity, where the motor can still drive the load. This way, the stepper motor never stalls and can drive heavy loads as fast as possible. Its higher torque available at lower velocity, plus dynamic torque from its flywheel mass allow compensating for mechanical torque peaks. In case the motor becomes completely blocked, the stall flag becomes set.

### 17.1 User Benefits

dcStep<sup>™</sup> Ap Acc Ent Ch

Motor Application Acceleration Energy efficiency Cheaper motor never loses steps works as fast as possible automatically as high as possible highest at speed limit

does the job!

### 17.2 Designing-In DcStep

In a classical application, the operation area is limited by the maximum torque required at maximum application velocity. A safety margin of up to 50% torque is required, in order to compensate for unforeseen load peaks, torque loss due to resonance and aging of mechanical components. DcStep allows using up to the full available motor torque. Even higher short time dynamic loads can be overcome using motor and application flywheel mass without the danger of a motor stall. With DcStep the nominal application load can be extended to a higher torque only limited by the safety margin near the holding torque area (which is the highest torque the motor can provide). Additionally, maximum application velocity can be increased up to the actually reachable motor velocity.



Figure 17.1 DcStep extended application operation area



www.trinamic.com

### 17.3 DcStep Integration with the Motion Controller

DcStep requires only a few settings. It directly feeds back motor motion to the ramp generator, so that it becomes seamlessly integrated into the motion ramp, even if the motor becomes overloaded with respect to the target velocity. DcStep operates the motor in fullstep mode at the ramp generator target velocity *VACTUAL* or at reduced velocity if the motor becomes overloaded. It requires setting the minimum operation velocity *VDCMIN*. *VDCMIN* shall be set to the lowest operating velocity where DcStep gives a reliable detection of motor operation. The motor never stalls unless it becomes braked to a velocity below *VDCMIN*. In case the velocity should fall below this value, the motor would restart once its load is released, unless the stall detection becomes enabled (set *sg\_stop*). Stall detection is covered by StallGuard2.



#### Hint

DcStep requires that the phase polarity of the sine wave is positive within the *MSCNT* range 768 to 255 and negative within 256 to 767. The cosine polarity must be positive from 0 to 511 and negative from 512 to 1023. A phase shift by 1 would disturb DcStep operation. Therefore it is advised to work with the default wave. Please refer chapter 18.2 for an initialization with the default table.

### 17.4 Stall Detection in DcStep Mode

While DcStep is able to decelerate the motor upon overload, it cannot avoid a stall in every operation situation. Once the motor is blocked, or it becomes decelerated below a motor dependent minimum velocity where the motor operation cannot safely be detected any more, the motor may stall and loose steps. In order to safely detect a step loss and avoid restarting of the motor, the stop on stall can be enabled (set flag *sg\_stop*). In this case *VACTUAL* becomes set to zero once the motor is stalled. It remains stopped until reading the *RAMP\_STAT* status flags. The flag *event\_stop\_sg* shows the active stop condition. A StallGuard2 load value also is available during DcStep operation. The range of values is limited to 0 to 255, in certain situations up to 511 will be read out. In order to enable StallGuard, also set *TCOOLTHRS* corresponding to a velocity slightly above *VDCMIN* or up to *VMAX*.

Stall detection in this mode may trigger falsely due to resonances, when flywheel loads are loosely coupled to the motor axis.

#### www.trinamic.com

| Parameter                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Range  | Comment                                                                                                                                                                                |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| vhighfs<br>&<br>vhighchm | These chopper configuration flags in CHOPCONF<br>need to be set for DcStep operation. As soon as<br>VDCMIN becomes exceeded, the chopper becomes<br>switched to fullstepping.                                                                                                                                                                                                                                                                                                                                                                                  | 0/1    | set to 1 for DcStep                                                                                                                                                                    |
| TOFF                     | DcStep often benefits from an increased off time value in CHOPCONF. Settings >2 should be preferred.                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 2 15   | Settings 815 do not make<br>any difference to setting 8<br>for DcStep operation.                                                                                                       |
| VDCMIN                   | This is the lower threshold for DcStep operation<br>when using internal ramp generator. Below this<br>threshold, the motor operates in normal microstep<br>mode. In DcStep operation, the motor operates at<br>minimum VDCMIN, even when it is completely<br>blocked. Tune together with DC_TIME setting.                                                                                                                                                                                                                                                      |        | 0: Disable DcStep<br>Set to the lower velocity<br>limit for DcStep operation.                                                                                                          |
| DC_TIME                  | Activation of StealthChop also disables DcStep.<br>This setting controls the reference pulse width for<br>DcStep load measurement. It must be optimized<br>for robust operation with maximum motor torque.<br>A higher value allows higher torque and higher<br>velocity, a lower value allows operation down to<br>a lower velocity as set by VDCMIN.<br>Check best setting under nominal operation<br>conditions, and re-check under extreme operating<br>conditions (e.g. lowest operation supply voltage,<br>highest motor temperature, and highest supply | 0 1023 | Lower limit for the setting<br>is: <i>t</i> <sub>BLANK</sub> (as defined by<br><i>TBL</i> ) in clock cycles + <i>n</i><br>with <i>n</i> in the range 1 to<br>100 (for a typical motor) |
| DC_SG                    | <ul> <li>voltage, lowest motor temperature).</li> <li>This setting controls stall detection in DcStep mode. Increase for higher sensitivity.</li> <li>A stall can be used as an error condition by issuing a hard stop for the motor. Enable sg_stop flag for stopping the motor upon a stall event. This way the motor will be stopped once it stalls.</li> </ul>                                                                                                                                                                                             |        | Set slightly higher than<br><i>DC_TIME I</i> 16                                                                                                                                        |

### 17.5 Measuring Actual Motor Velocity in DcStep Operation

DcStep has the ability to reduce motor velocity in case the motor becomes slower than the target velocity due to mechanical load. VACTUAL shows the ramp generator target velocity. It is not influenced by DcStep. Measuring DcStep velocity is possible based on the position counter XACTUAL.

Therefore take two snapshots of the position counter with a known time difference:  

$$VACTUAL_{DCSTEP} = \frac{XACTUAL(time2) - XACTUAL(time1)}{time2 - time1} * \frac{2^{24}}{f_{CLK}}$$

Example:

At 16.0 MHz clock frequency, a 0.954 second measurement delay would directly yield in the velocity value, a 9.54 ms delay would yield in 1/100 of the actual DcStep velocity.

To grasp the time interval as precisely as possible, snapshot a timer each time the transmission of *XACTUAL* from the IC starts or ends. The rising edge of NCS for SPI transmission provides the most exact time reference.

www.trinamic.com

### 17.6 DcStep with STEP/DIR Interface

The TMC5160 provides two ways to use DcStep when interfaced to an external motion controller. The first way gives direct control of the DcStep step execution to the external motion controller, which must react to motor overload and is allowed to override a blocked motor situation. The second way assumes that the external motion controller cannot directly react to DcStep signals. The TMC5160 automatically reduces the motor velocity or stops the motor upon overload. In order to allow the motion controller to react to the reduced real motor velocity in this mode, the counter *LOST\_STEPS* gives the number of steps which have been commanded, but not taken by the motor controller. The motion controller can later on read out *LOST\_STEPS* and drive any missing number of steps. In case of a blocked motor it tries moving it with the minimum velocity as programmed by *VDCMIN*.

Enabling DcStep automatically sets the chopper to constant TOFF mode with slow decay only. This way, no re-configuration is required when switching from microstepping mode to DcStep and back.

DcStep operation is controlled by three pins in STEP and DIR mode:

- DCEN Forces the driver to DcStep operation if high. A velocity based activation of DcStep is controlled by *TPWMTHRS* when using StealthChop operation for low velocity settings. In this case, DcStep is disabled while in StealthChop mode, i.e. at velocities below the StealthChop switching velocity.
- DCO Informs the motion controller when motor is not ready to take a new step (low level). The motion controller shall react by delaying the next step until DCO becomes high. The sequencer can buffer up to the effective number of microsteps per fullstep to allow the motion controller to react to assertion of DCO. In case the motor is blocked this wait situation can be terminated after a timeout by providing a long > 1024 clock STEP input, or via the internal VDCMIN setting.
- DCIN Commands the driver to wait with step execution and to disable DCO. This input can be used for synchronization of multiple drivers operating with DcStep.

### 17.6.1 Using LOST\_STEPS for DcStep Operation

This is the simplest possibility to integrate DcStep with an external motion controller: The external motion controller enables DcStep using DCEN or the internal velocity threshold. The TMC5160 tries to follow the steps. In case it needs to slow down the motor, it counts the difference between incoming steps on the STEP signal and steps going to the motor. The motion controller can read out the difference and compensate for the difference after the motion or on a cyclic basis. Figure 17.3 shows the principle (simplified).

In case the motor driver needs to postpone steps due to detection of a mechanical overload in DcStep, and the motion controller does not react to this by pausing the step generation, *LOST\_STEPS* becomes incremented or decremented (depending on the direction set by DIR) with each step which is not taken. This way, the number of lost steps can be read out and executed later on or be appended to the motion. As the driver needs to slow down the motor while the overload situation persists, the application will benefit from a high microstepping resolution, because it allows more seamless acceleration or deceleration in DcStep operation. In case the application is completely blocked, *VDCMIN* sets a lower limit to the step execution. If the motor velocity falls below this limit, however an unknown number of steps is lost and the motor position is not exactly known any more. DCIN allows for step synchronization of two drivers: it stops the execution of steps if low and sets DCO low.

www.trinamic.com



Figure 17.3 Motor moving slower than STEP input due to light overload. LOSTSTEPS incremented

### 17.6.2 DCO Interface to Motion Controller

In STEP/DIR mode, DCEN enables DcStep. It is up to the external motion controller to enable DcStep either, once a minimum step velocity is exceeded within the motion ramp, or to use the automatic threshold *VDCMIN* for DcStep enable.

The STEP/DIR interface works in microstep resolution, even if the internal step execution is based on fullstep. This way, no switching to a different mode of operation is required within the motion controller. The DcStep output DCO signals if the motor is ready for the next step based on the DcStep measurement of the motor. If the motor has not yet mechanically taken the last step, this step cannot be executed, and the driver stops automatically before execution of the next fullstep. This situation is signaled by DCO. The external motion controller shall stop step generation if DCOUT is low and wait until it becomes high again. Figure 17.5 shows this principle. The driver buffers steps during the waiting period up to the number of microstep setting minus one. In case, DCOUT does not go high within the lower step limit time e.g. due to a severe motor overload, a step can be enforced: override the stop status by a long STEP pulse with min. 1024 system clocks length. When using internal clock, a pulse length of minimum 125µs is recommended.



Figure 17.4 Full signal interconnection for DcStep

www.trinamic.com



Figure 17.5 DCO Interface to motion controller - step generator stops when DCO is asserted



www.trinamic.com

# 18 Sine-Wave Look-up Table

The TMC5160 driver provides a programmable look-up table for storing the microstep current wave. As a default, the table is pre-programmed with a sine wave, which is a good starting point for most stepper motors. Reprogramming the table to a motor specific wave allows drastically improved microstepping especially with low-cost motors.

### 18.1 User Benefits

| Microstepping | - | extremely improved with low cost motors              |
|---------------|---|------------------------------------------------------|
| Motor         | - | runs smooth and quiet                                |
| Torque        | - | reduced mechanical resonances yields improved torque |

### 18.2 Microstep Table

In order to minimize required memory and the amount of data to be programmed, only a quarter of the wave becomes stored. The internal microstep table maps the microstep wave from 0° to 90°. It becomes symmetrically extended to  $360^\circ$ . When reading out the table the 10-bit microstep counter *MSCNT* addresses the fully extended wave table. The table is stored in an incremental fashion, using each one bit per entry. Therefore only 256 bits (*ofs00* to *ofs255*) are required to store the quarter wave. These bits are mapped to eight 32 bit registers. Each *ofs* bit controls the addition of an inclination *Wx* or *Wx*+1 when advancing one step in the table. When *Wx* is 0, a 1 bit in the table at the actual microstep position means "add one" when advancing to the next microstep. As the wave can have a higher inclination than 1, the base inclinations *Wx* can be programmed to -1, 0, 1, or 2 using up to four flexible programmable segments within the quarter wave. This way even negative inclination can be realized. The four inclination segments are controlled by the position registers *X*1 to *X3*. Inclination segment 0 goes from *X*1 to *X2*-1 with its base inclination controlled by *W1*, etc.

When modifying the wave, care must be taken to ensure a smooth and symmetrical zero transition when the quarter wave becomes expanded to a full wave. The maximum resulting swing of the wave should be adjusted to a range of -248 to 248, in order to give the best possible resolution while leaving headroom for the hysteresis based chopper to add an offset.



Figure 18.1 LUT programming example

#### www.trinamic.com

When the microstep sequencer advances within the table, it calculates the actual current values for the motor coils with each microstep and stores them to the registers *CUR\_A* and *CUR\_B*. However the incremental coding requires an absolute initialization, especially when the microstep table becomes modified. Therefore *CUR\_A* and *CUR\_B* become initialized whenever *MSCNT* passes zero.

Two registers control the starting values of the tables:

- As the starting value at zero is not necessarily 0 (it might be 1 or 2), it can be programmed into the starting point register *START\_SIN*.
- In the same way, the start of the second wave for the second motor coil needs to be stored in START\_SIN90. This register stores the resulting table entry for a phase shift of 90° for a 2phase motor.

Hint

Refer chapter 6.5 for the register set and for the default table function stored in the drivers. The default table is a good base for realizing an own table. The TMC5160-EVAL comes with a calculation tool for own waves.

Initialization example for the default microstep table:

| MSLUT[0]= %1 | 010101010 <mark>10</mark> | 10101011 | 010101010100  | ) = 0xAA           | AB554  |
|--------------|---------------------------|----------|---------------|--------------------|--------|
| MSLUT[1]= %0 |                           |          |               |                    |        |
| MSLUT[2]= %0 |                           |          |               |                    |        |
| MSLUT[3]= %0 |                           |          |               |                    |        |
| MSLUT[4]= %1 | 11110111111               | 11111111 | 1111111111111 | $= 0 \times FBF$   | FFFFF  |
| MSLUT[5]= %1 | 01101011011               | 10110111 | 011101111101  | $L = 0 \times B5E$ | 3B777D |
| MSLUT[6]= %0 |                           |          |               |                    |        |
| MSLUT[7]= %0 | 0000000100                | 00000100 | 001000100010  | $ = 0 \times 004 $ | 04222  |

MSLUTSEL= 0xFFF8056: X1=128, X2=255, X3=255 W3=%01, W2=%01, W1=%01, W0=%10

MSLUTSTART= 0x00F70000: START\_SIN\_0= 0, START\_SIN90= 247

### **19 Emergency Stop**

The driver provides a negative active enable pin ENN to safely switch off all power MOSFETs. This allows putting the motor into freewheeling. Further, it is a safe hardware function whenever an emergency-stop not coupled to software is required. Some applications may require the driver to be put into a state with active holding current or with a passive braking mode. This is possible by programming the pin ENCA\_DCIN to act as a step disable function. Set GCONF flag *stop\_enable* to activate this option. Whenever ENCA\_DCIN becomes pulled up, the motor will stop abruptly and go to the power down state, as configured via *IHOLD, IHOLDDELAY* and StealthChop standstill options. Disabling the driver via ENN will require three clock cycles to safely switch off the driver.

www.trinamic.com

# 20 ABN Incremental Encoder Interface

The TMC5160 is equipped with an incremental encoder interface for ABN encoders. The encoder inputs are multiplexed with other signals in order to keep the pin count of the device low. The basic selection of the peripheral configuration is set by the register *GCONF*. The use of the N channel is optional, as some applications might use a reference switch or stall detection rather than an encoder N channel for position referencing. The encoders give positions via digital incremental quadrature signals (usually named A and B) and a clear signal (usually named N for null or Z for zero).

### N SIGNAL

The N signal can be used to clear the position counter or to take a snapshot. To continuously monitor the N channel and trigger clearing of the encoder position or latching of the position, where the N channel event has been detected, set the flag *clr\_cont*. Alternatively it is possible to react to the next encoder N channel event only, and automatically disable the clearing or latching of the encoder position after the first N signal event (flag *clr\_once*). This might be desired because the encoder gives this signal once for each revolution.

Some encoders require a validation of the N signal by a certain configuration of A and B polarity. This can be controlled by *pol\_A* and *pol\_B* flags in the *ENCMODE* register. For example, when both *pol\_A* and *pol\_B* are set, an active N-event is only accepted during a high polarity of both, A and B channel.



### THE ENCODER CONSTANT ENC\_CONST

The encoder constant *ENC\_CONST* is added to or subtracted from the encoder counter on each polarity change of the quadrature signals AB of the incremental encoder. The encoder constant *ENC\_CONST* represents a signed fixed point number (16.16) to facilitate the generic adaption between motors and encoders. In decimal mode, the lower 16 bits represent a number between 0 and 9999. For stepper motors equipped with incremental encoders the fixed number representation allows very comfortable parameterization. Additionally, mechanical gearing can easily be taken into account. Negating the sign of *ENC\_CONST* allows inversion of the counting direction to match motor and encoder direction.

#### Examples:

- Encoder factor of 1.0: ENC\_CONST = 0x0001.0x0000 = FACTOR.FRACTION
- Encoder factor of -1.0: ENC\_CONST = 0xFFFF.0x0000. This is the two's complement of 0x00010000. It equals (2^16-(FACTOR+1)).(2^16-FRACTION)
- Decimal mode encoder factor 25.6: 00025.6000 = 0x0019.0x1770 = FACTOR.DECIMALS

www.trinamic.com

 Decimal mode encoder factor -25.6: 0xFFE6.4000 = 0xFFE6.0x0FA0. This equals (2<sup>16</sup>-(FACTOR+1)).(10000-DECIMALS)

#### THE ENCODER COUNTER X\_ENC

The encoder counter X\_ENC holds the current encoder position ready for read out. Different modes concerning handling of the signals A, B, and N take into account active low and active high signals found with different types of encoders. For more details please refer to the register mapping in section 6.4.

#### THE REGISTER ENC\_STATUS

The register *ENC\_STATUS* holds the status concerning the event of an encoder clear upon an N channel signals. The register *ENC\_LATCH* stores the actual encoder position on an N signal event.

### 20.1 Encoder Timing

The encoder inputs use analog and digital filtering to ensure reliable operation even with increased cable length. The maximum continuous counting rate is limited by input filtering to 2/3 of  $f_{CLK}$ .

| Encoder interface timing   | AC-Characteristics<br>clock period is t <sub>CLK</sub> |                    |                        |                       |                  |      |
|----------------------------|--------------------------------------------------------|--------------------|------------------------|-----------------------|------------------|------|
| Parameter                  | Symbol                                                 | Conditions         | Min                    | Тур                   | Max              | Unit |
| Encoder counting frequency | f <sub>CNT</sub>                                       |                    |                        | <2/3 f <sub>CLK</sub> | f <sub>clк</sub> |      |
| A/B/N input low time       | t <sub>abnl</sub>                                      |                    | 3 t <sub>CLK</sub> +20 |                       |                  | ns   |
| A/B/N input high time      | tabnh                                                  |                    | 3 tclk+20              |                       |                  | ns   |
| A/B/N spike filtering time | t <sub>filtabn</sub>                                   | Rising and falling |                        | 3 t <sub>CLK</sub>    |                  |      |
|                            |                                                        | edge               |                        |                       |                  |      |

### 20.2 Setting the Encoder to Match Motor Resolution

Encoder example settings for motor parameters: USC=256 µsteps, 200 fullstep motor Factor = FSC\*USC / encoder resolution

| ENCODER EXAMPLE SETTINGS FOR A 200 FULLSTEP MOTOR WITH 256 MICROSTEPS |                                                             |                                  |  |  |  |
|-----------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------|--|--|--|
| Encoder resolution                                                    | Required encoder factor                                     | Comment                          |  |  |  |
| 200                                                                   | 256                                                         |                                  |  |  |  |
| 360                                                                   | 142.2222<br>= 9320675.5555 / 2^16<br>= 1422222.2222 / 10000 | No exact match possible!         |  |  |  |
| 500                                                                   | 102.4<br>= 6710886.4 / 2^16<br>= 1024000 / 10000            | Exact match with decimal setting |  |  |  |
| 1000                                                                  | 51.2                                                        | Exact match with decimal setting |  |  |  |
| 1024                                                                  | 50                                                          |                                  |  |  |  |
| 4000                                                                  | 12.8                                                        | Exact match with decimal setting |  |  |  |
| 4096                                                                  | 12.5                                                        |                                  |  |  |  |
| 16384                                                                 | 3.125                                                       |                                  |  |  |  |

Example:

The encoder constant register shall be programmed to 51.2 in decimal mode. Therefore, set  $ENC\_CONST = 51 * 2^{16} + 0.2 * 10000$ 

108

### www.trinamic.com

#### 20.3 Closing the Loop

Depending on the application, an encoder can be used for different purposes. Medical applications often require an additional and independent monitoring to detect hard or soft failure. Upon failure, the machine can be stopped and restarted manually. Use *ENC\_DEVIATION* setting and interrupt to safely detect a step loss failure / mismatch between motor and encoder.

Less critical applications may use the encoder to detect failure, stop the motors upon step loss and restart automatically. A different use of the encoder allows increased positioning precision by positioning directly to encoder positions. The application can modify target positions based on the deviation, or even regularly update the actual position with the encoder position.

To realize a directly encoder based commutation, TRINAMIC offers the new S-ramp closed loop motion controller TMC4361.



www.trinamic.com

### 21 DC Motor or Solenoid

The TMC5160 can drive one or two DC motors using one coil output per DC motor. Either a torque limited operation, or a voltage based velocity control with optional torque limit is possible.

#### **CONFIGURATION AND CONTROL**

Set the flag *direct\_mode* in the *GCONF* register. In direct mode, the coil current polarity and coil current, respectively the PWM duty cycle become controlled by register *XTARGET* (0x2D). Bits 8..0 control motor A and Bits 24..16 control motor B PWM. Additionally to this setting, the current limit is scaled by *IHOLD*. The STEP/DIR inputs and the motion controller are not used in this mode.

#### PWM DUTY CYCLE VELOCITY CONTROL

In order to operate the motor at different velocities, use the StealthChop voltage PWM mode in the following configuration:

```
en_pwm_mode = 1, pwm_autoscale = 0, PWM_AMPL = 255, PWM_GRAD = 4, IHOLD = 31
Set TOFF > 0 to enable the driver.
```

In this mode the driver behaves like a 4-quadrant power supply. The direct mode setting of PWM A and PWM B using XTARGET controls motor voltage, and thus the motor velocity. Setting the corresponding PWM bits between -255 and +255 (signed, two's complement numbers) will vary motor voltage from -100% to 100%. With *pwm\_autoscale* = 0, current sensing is not used and the sense resistors should be eliminated or  $150m\Omega$  or less to avoid excessive voltage drop when the motor becomes heavily loaded up to 2.5A. Especially for higher current motors, make sure to slowly accelerate and decelerate the motor in order to avoid overcurrent or triggering driver overcurrent detection.

To activate optional motor freewheeling, set IHOLD = 0 and FREEWHEEL = %01.

#### ADDITIONAL TORQUE LIMIT

In order to additionally take advantage of the motor current limitation (and thus torque controlled operation) in StealthChop mode, use automatic current scaling (*pwm\_autoscale* = 1). The actual current limit is given by *IHOLD* and scaled by the respective motor PWM amplitude, e.g. PWM = 128 yields in 50% motor velocity and 50% of the current limit set by *IHOLD*. In case two DC motors are driven in voltage PWM mode, note that the automatic current regulation will work only for the motor which has the higher absolute PWM setting. The PWM of the second motor also will be scaled down in case the motor with higher PWM setting reaches its current limitation.

#### PURELY TORQUE LIMITED OPERATION

For a purely torque limited operation of one or two motors, spread cycle chopper individually regulates motor current for both full bridge motor outputs. When using SpreadCycle, the upper motor velocity is limited by the supply voltage only (or as determined by the load on the motor).

#### 21.1 Solenoid Operation

The same way, one or two solenoids (i.e. magnetic coil actuators) can be operated using SpreadCycle chopper. For solenoids, it is often desired to have an increased current for a short time after switching on, and reduce the current once the magnetic element has switched. This is automatically possible by taking advantage of the automatic current scaling (*IRUN*, *IHOLD*, *IHOLDDELAY* and *TPOWERDOWN*). The current scaling in *direct\_mode* is still active, but will not be triggered if no step impulse is supplied. Therefore, a step impulse must be given to the STEP input whenever one of the coils shall be switched on. This will increase the current for both coils at the same time.

www.trinamic.com

### 22 Quick Configuration Guide

This guide is meant as a practical tool to come to a first configuration and do a minimum set of measurements and decisions for tuning the driver. It does not cover all advanced functionalities, but concentrates on the basic function set to make a motor run smoothly. Once the motor runs, you may decide to explore additional features, e.g. freewheeling and further functionality in more detail. A current probe on one motor coil is a good aid to find the best settings, but it is not a must.

#### CURRENT SETTING AND FIRST STEPS WITH STEALTHCHOP



Figure 22.1 Current setting and first steps with StealthChop

www.trinamic.com

#### TUNING STEALTHCHOP AND SPREADCYCLE



#### Figure 22.2 Tuning StealthChop and SpreadCycle

www.trinamic.com



#### MOVING THE MOTOR USING THE MOTION CONTROLLER

Figure 22.3 Moving the motor using the motion controller

www.trinamic.com





Figure 22.4 Enabling CoolStep (only in combination with SpreadCycle)

www.trinamic.com

#### SETTING UP DCSTEP



Figure 22.5 Setting up DcStep

www.trinamic.com

### 23 Getting Started

Please refer to the TMC5160 evaluation board to allow a quick start with the device, and in order to allow interactive tuning of the device setup in your application. Chapter 22 will guide you through the process of correctly setting up all registers.

#### **23.1** Initialization Examples

SPI datagram example sequence to enable the driver for step and direction operation and initialize the chopper for SpreadCycle operation and for StealthChop at <30 RPM @ 12MHz clock:

SPI send: 0xEC000100C3; // CHOPCONF: TOFF=3, HSTRT=4, HEND=1, TBL=2, CHM=0 (SpreadCycle) SPI send: 0x9000061F0A; // IHOLD\_IRUN: IHOLD=10, IRUN=31 (max. current), IHOLDDELAY=6 SPI send: 0x910000000A; // TPOWERDOWN=10: Delay before power down in stand still SPI send: 0x8000000004; // EN\_PWM\_MODE=1 enables StealthChop (with default PWM\_CONF) SPI send: 0x93000001F4; // TPWM\_THRS=500 yields a switching velocity about 35000 = ca. 30RPM

SPI sample sequence to enable and initialize the motion controller and move one rotation (51200 microsteps) using the ramp generator. A read access querying the actual position is also shown.

| SPI send: 0xA4000003E8;    | // A1 = 1 000 First acceleration                                 |
|----------------------------|------------------------------------------------------------------|
| SPI send: 0xA50000C350;    | // V1 = 50 000 Acceleration threshold velocity V1                |
| SPI send: 0xA6000001F4;    | // AMAX = 500 Acceleration above V1                              |
| SPI send: 0xA700030D40;    | // VMAX = 200 000                                                |
| SPI send: 0xA8000002BC;    | // DMAX = 700 Deceleration above V1                              |
| SPI send: 0xAA00000578;    | // D1 = 1400 Deceleration below V1                               |
| SPI send: 0xAB0000000A;    | // VSTOP = 10 Stop velocity (Near to zero)                       |
| SPI send: 0xA00000000;     | // RAMPMODE = 0 (Target position move)                           |
| // Ready to move!          |                                                                  |
| SPI send: 0xADFFFF3800;    | // XTARGET = -51200 (Move one rotation left (200*256 microsteps) |
| // Now motor 1 starts rota | ating                                                            |
| SPI send: 0x210000000;     | // Query XACTUAL – The next read access delivers XACTUAL         |
| SPI read;                  | // Read XACTUAL                                                  |

For UART based operation it is important to make sure that the CRC byte is correct. The following example shows initialization for the driver with slave address 1 (NAI pin high). It programs the driver to SpreadCycle mode and programs the motion controller for a constant velocity move and then read accesses the position and actual velocity registers:

| UART write: 0x05 0x01 0xEC 0x00 0x01 0x00 0xC5 0xD3; // TOFF=5, HEND=1, HSTR=4,        |
|----------------------------------------------------------------------------------------|
| // TBL=2, MRES=0, CHM=0                                                                |
| UART write: 0x05 0x01 0x90 0x00 0x01 0x14 0x05 0xD8; // IHOLD=5, IRUN=20, IHOLDDELAY=1 |
| UART write: 0x05 0x01 0xA6 0x00 0x00 0x13 0x88 0xB4; // AMAX=5000                      |
| UART write: 0x05 0x01 0xA7 0x00 0x00 0x4E 0x20 0x85; // VMAX=20000                     |
| UART write: 0x05 0x01 0xA0 0x00 0x00 0x00 0x01 0xA3; // RAMPMODE=1 (positive velocity) |
| // Now motor should start rotating                                                     |
| UART write: 0x05 0x01 0x21 0x6B; // Query XACTUAL                                      |
| UART read 8 bytes;                                                                     |
| UART write: 0x05 0x01 0x22 0x25; // Query VACTUAL                                      |
| UART read 8 bytes;                                                                     |

Hint

Tune the configuration parameters for your motor and application for optimum performance.

www.trinamic.com

### 24 Standalone Operation

For standalone operation, no SPI interface is required to configure the TMC5160. All pins with suffix CFG0 to CFG6 have a special meaning in this mode and can bei tied either to VCC\_IO or to GND.



Figure 24.1 Standalone operation with TMC5160 (pins shown with their standalone mode names)

To activate standalone mode, tie pin SPI\_MODE to GND and pin SD\_MODE high. In this mode, the driver acts as a pure STEP and DIR driver. SPI and single wire are off. The driver works in SpreadCycle mode or StealthChop mode. With regard to the register set, the following settings are activated:

| CFG0/CF | G1: CONF | IGURATION OF MICROSTEP RESOLUTION FOR STEP INPUT |
|---------|----------|--------------------------------------------------|
| CFG1    | CFG0     | Microstep Setting                                |
| GND     | GND      | 8 microsteps, MRES=5                             |
| GND     | VCC_IO   | 16 microsteps, MRES=4                            |
| VCC_IO  | GND      | 32 microsteps, MRES=3                            |
| VCC_IO  | VCC_IO   | 64 microsteps, MRES=2                            |

The following settings are affected by the CFG pins in order to ensure correct configuration:

www.trinamic.com

| CFG4/CF | CFG4/CFG3/CFG2: CONFIGURATION OF RUN CURRENT |        |              |  |  |  |
|---------|----------------------------------------------|--------|--------------|--|--|--|
| CFG4    | CFG3                                         | CFG2   | IRUN Setting |  |  |  |
| GND     | GND                                          | GND    | IRUN=16      |  |  |  |
| GND     | GND                                          | VCC_IO | IRUN=18      |  |  |  |
| GND     | VCC_IO                                       | GND    | IRUN=20      |  |  |  |
| GND     | VCC_IO                                       | VCC_IO | IRUN=22      |  |  |  |
| VCC_IO  | GND                                          | GND    | IRUN=24      |  |  |  |
| VCC_IO  | GND                                          | VCC_IO | IRUN=26      |  |  |  |
| VCC_IO  | VCC_IO                                       | GND    | IRUN=28      |  |  |  |
| VCC_IO  | VCC_IO                                       | VCC_IO | IRUN=31      |  |  |  |

| CFG5 Cho   | opper Setting                             |
|------------|-------------------------------------------|
| GND Spr    | eadCycle operation. (TOFF=3)              |
| VCC_IO Ste | althChop operation. (GCONF.en_PWM_mode=1) |

| CFG6: CONFIGURATION OF HOLD CURRENT REDUCTION |                                       |  |  |  |  |  |
|-----------------------------------------------|---------------------------------------|--|--|--|--|--|
| CFG6*)                                        | Chopper Setting                       |  |  |  |  |  |
| GND                                           | No hold current reduction. IHOLD=IRUN |  |  |  |  |  |
| VCC_IO                                        | Reduction to 50%. IHOLD=1/2 IRUN      |  |  |  |  |  |

#### Hint

Be sure to allow the motor to rest for at least 100ms (assuming a minimum of 10MHz  $f_{CLK}$ ) before starting a motion using StealthChop. This will allow the current regulation to set the initial motor current.

#### \*) CFG6: Attention

CFG6 pin draws significant current (20mA) when driven to a different level than CFG5, because the output driver tries to make CFG6 level equal to CFG5. Therefore, a 0 Ohm resistor is required to pull up/down CFG6. Due to this, setting CFG6 different from CFG5 is only recommended with external VCC IO supply at 3.3V level.

Attention:

DIAG outputs are not configured per default. They can be activated using the interfaces before switching to standalone mode.

ELECTRON

www.trinamic.com

### 25 External Reset

The chip is loaded with default values during power on via its internal power-on reset. In order to reset the chip to power on defaults, any of the supply voltages monitored by internal reset circuitry (VSA, +5VOUT or VCC\_IO) must be cycled. VCC is not monitored. Therefore VCC must not be switched off during operation of the chip. As +5VOUT is the output of the internal voltage regulator, it cannot be cycled via an external source except by cycling VSA. It is easiest and safest to cycle VCC\_IO in order to completely reset the chip. Also, current consumed from VCC\_IO is low and therefore it has simple driving requirements. Due to the input protection diodes not allowing the digital inputs to rise above VCC\_IO level, all inputs must be driven low during this reset operation. When this is not possible, an input protection resistor may be used to limit current flowing into the related inputs.

In case, VCC becomes supplied by an external source, make sure that VCC is at a stable value above the lower operation limit once the reset ends. This normally is satisfied when generating a 3.3V VCC\_IO from the +5V supply supplying the VCC pin, because it will then come up with a certain delay.

### 26 Clock Oscillator and Input

The clock is the timing reference for all functions: the chopper, the velocity, the acceleration control, etc. Many parameters are scaled with the clock frequency, thus a precise reference allows a more deterministic result. The factory-trimmed on-chip clock oscillator provides timing in case no external clock is easily available.

#### 26.1 Using the Internal Clock

Directly tie the CLK input to GND near to the IC if the internal clock oscillator is to be used. It will be sufficient for applications, where a velocity precision of roughly +-4% is tolerable.

#### 26.2 Using an External Clock

When an external clock is available, a frequency of 10 MHz to 16 MHz is recommended for optimum performance. The duty cycle of the clock signal is uncritical, as long as minimum high or low input time for the pin is satisfied (refer to electrical characteristics). Up to 18 MHz can be used, when the clock duty cycle is 50%. Make sure, that the clock source supplies clean CMOS output logic levels and steep slopes when using a high clock frequency. The external clock input is enabled with the second positive polarity seen on the CLK input.

#### Hint

Switching off the external clock frequency prevents the driver from operating normally. Therefore an internal watchdog switches back to internal clock in case the external signal is missing for more than roughly 32 internal clock cycles.

#### 26.2.1 Considerations on the Frequency

A higher frequency allows faster step rates, faster SPI operation and higher chopper frequencies. On the other hand, it causes more power dissipation in the TMC5160 digital core and 5V voltage regulator. Generally a frequency of 10 MHz to 12 MHz should be sufficient for most applications. At higher clock frequency, the VSA supply voltage should be connected to a lower voltage for applications working at more than 24V nominal supply voltage. For reduced requirements concerning the motor dynamics, a clock frequency of down to 8 MHz (or even lower) can be considered.

www.trinamic.com

## 27 Absolute Maximum Ratings

The maximum ratings may not be exceeded under any circumstances. Operating the circuit at or near more than one maximum rating at a time for extended periods shall be avoided by application design.

| Parameter                                                                          | Symbol                      | Min  | Max                   | Unit |
|------------------------------------------------------------------------------------|-----------------------------|------|-----------------------|------|
| Supply voltage operating with inductive load                                       | Vvs, Vvsa                   | -0.5 | 60                    | V    |
| Supply and bridge voltage short time peak (limited by                              | VUSMAX                      |      | 64                    | V    |
| peak voltage on charge pump output and Cxx pins*)                                  | V VSMAX                     |      |                       |      |
| VSA when different from VS                                                         | V <sub>VSAMAX</sub>         | -0.5 | 60                    | V    |
| Peak voltages on Cxx bootstrap pins and VCP                                        | V <sub>CxCP</sub>           |      | 76                    | V    |
| Supply voltage V12                                                                 | V <sub>12VOUT</sub>         | -0.5 | 14                    | V    |
| Peak voltages on BM pins (due to stray inductivity)                                | V <sub>BMx</sub>            | -6   | V <sub>VS</sub> +6    | V    |
| Peak voltages on Cxx bootstrap pins relative to BM                                 | V <sub>CxBMx</sub>          | -0.5 | 16                    | V    |
| I/O supply voltage on VCC_IO                                                       | V <sub>VIO</sub>            | -0.5 | 5.5                   | V    |
| digital VCC supply voltage (normally supplied by 5VOUT)                            | V <sub>VCC</sub>            | -0.5 | 5.5                   | V    |
| Logic input voltage                                                                | VI                          | -0.5 | V <sub>VI0</sub> +0.5 | V    |
| Maximum current to / from digital pins                                             | I <sub>IO</sub>             |      | +/-500                | mA   |
| and analog low voltage I/Os (short time peak current)                              |                             |      |                       |      |
| 5V regulator output current (internal plus external load)                          | $\mathbf{I}_{\text{5VOUT}}$ |      | 30                    | mA   |
| 5V regulator continuous power dissipation ( $V_{VSA}$ -5V) * $I_{5VOUT}$           | P <sub>5VOUT</sub>          |      | 1                     | W    |
| 12V regulator output current (internal plus external load)                         | I <sub>12VOUT</sub>         |      | 20                    | mA   |
| 12V regulator cont. power dissipation (V <sub>VM</sub> -12V) * I <sub>12VOUT</sub> | P <sub>12VOUT</sub>         |      | 0.5                   | W    |
| Junction temperature                                                               | TJ                          | -50  | 150                   | °C   |
| Storage temperature                                                                | T <sub>STG</sub>            | -55  | 150                   | °C   |
| ESD-Protection for interface pins (Human body model,                               | VESDAP                      |      | 4                     | kV   |
| HBM)                                                                               |                             |      |                       |      |
| ESD-Protection for handling (Human body model, HBM)                                | V <sub>ESD</sub>            |      | 1                     | kV   |

\*) Stray inductivity of power routing will lead to ringing of the supply voltage when driving an inductive load. This ringing results from the fast switching slopes of the driver outputs in combination with reverse recovery of the body diodes of the output driver MOSFETs. Even small trace inductivities as well as stray inductivity of sense resistors can easily generate a few volts of ringing leading to temporary voltage overshoot. This should be considered when working near the maximum voltage.

## **28 Electrical Characteristics**

### 28.1 Operational Range

| Parameter                                               | Symbol              | Min  | Max  | Unit |
|---------------------------------------------------------|---------------------|------|------|------|
| Junction temperature                                    | Tj                  | -40  | 125  | °C   |
| Supply voltage for motor and bridge                     | V <sub>VS</sub>     | 10   | 55   | V    |
| Supply voltage VSA                                      | V <sub>VSA</sub>    | 10   | 50   | V    |
| Supply voltage for VSA and 12OUT (internal gate voltage | V <sub>12VOUT</sub> | 10   | 13   | V    |
| regulator bridged)                                      | V <sub>VSA</sub>    |      |      |      |
| Lower Supply voltage (reduced spec, short to GND        |                     | 8    |      | V    |
| protection not functional), lower limit depending on    | V <sub>vs</sub>     |      |      |      |
| MOSFETs gate threshold voltage and load current         |                     |      |      |      |
| I/O supply voltage on VCC_IO                            | V <sub>VIO</sub>    | 3.00 | 5.25 | V    |

-

CT.

DAN

www.trinamic.com

### 28.2 DC and Timing Characteristics

DC characteristics contain the spread of values guaranteed within the specified supply voltage range unless otherwise specified. Typical values represent the average value of all parts measured at +25°C. Temperature variation also causes stray to some values. A device with typical values will not leave Min/Max range within the full temperature range.

| Power supply current             | DC-Characteristics |                                      |     |      |     |      |  |  |
|----------------------------------|--------------------|--------------------------------------|-----|------|-----|------|--|--|
|                                  | $V_{VS} = V_{VSA}$ | $J_{\rm VS}$ = $V_{\rm VSA}$ = 24.0V |     |      |     |      |  |  |
| Parameter                        | Symbol             | Conditions                           | Min | Тур  | Max | Unit |  |  |
| Total supply current, driver     | Is                 | f <sub>CLK</sub> =12MHz / internal   |     | 18   | 24  | mA   |  |  |
| disabled $I_{VS}$ + $I_{VSA}$    |                    | clock                                |     |      |     |      |  |  |
| VSA supply current (VS and VSA   | $I_{\text{VSA}}$   | f <sub>CLK</sub> =12MHz / internal   |     | 15   |     | mA   |  |  |
| separated)                       |                    | clock, driver disabled               |     |      | 1   |      |  |  |
| Total supply current, operating, | Is                 | f <sub>CLK</sub> =12MHz, 23.4kHz     |     | 25   |     | mA   |  |  |
| MOSFETs AOD4126, Ivs + Ivsa      |                    | chopper, no load                     |     |      |     |      |  |  |
| Internal current consumption     | Ivcc               | f <sub>CLK</sub> =12MHz              |     | 10   |     | mA   |  |  |
| from 5V supply on VCC pin        |                    |                                      |     |      |     |      |  |  |
| Internal current consumption     | Ivcc               | f <sub>CLK</sub> =16MHz              |     | 12.5 |     | mA   |  |  |
| from 5V supply on VCC pin        |                    |                                      |     |      |     |      |  |  |
| IO supply current on VCC_IO      | I <sub>VIO</sub>   | no load on outputs,                  |     | 15   | 30  | μA   |  |  |
| (typ. at 5V)                     |                    | inputs at $V_{IO}$ or GND            |     |      |     |      |  |  |
|                                  |                    | Excludes pullup /                    |     |      |     |      |  |  |
|                                  |                    | pull-down resistors                  |     |      |     |      |  |  |

| Motor driver section                    | DC- and Timing-Characteristics<br>Vvs = 24.0V; Tj=50°C |               |     |     |     |      |  |  |
|-----------------------------------------|--------------------------------------------------------|---------------|-----|-----|-----|------|--|--|
| Parameter                               | Symbol                                                 | Conditions    | Min | Тур | Max | Unit |  |  |
| RDS <sub>ON</sub> lowside off driver    | RONL                                                   | Gate off      |     | 1.8 | 3   | Ω    |  |  |
| RDS <sub>ON</sub> highside off driver   | RONH                                                   | Gate off      |     | 2.2 | 3.5 | Ω    |  |  |
| Gate drive current low side             | ISLPONO                                                | DRVSTRENGTH=0 |     | 200 |     | mA   |  |  |
| MOSFET turning on at 2V V <sub>GS</sub> | I <sub>SLPON2</sub>                                    | DRVSTRENGTH=2 |     | 400 |     | mA   |  |  |
|                                         | <b>I</b> <sub>SLPON3</sub>                             | DRVSTRENGTH=3 |     | 600 |     | mA   |  |  |
| Gate drive current high side            | I <sub>SLPONO</sub>                                    | DRVSTRENGTH=0 |     | 150 |     | mA   |  |  |
| MOSFET turning on at 2V $V_{GS}$        | I <sub>SLPON2</sub>                                    | DRVSTRENGTH=2 |     | 300 |     | mA   |  |  |
|                                         | I <sub>SLPON3</sub>                                    | DRVSTRENGTH=3 |     | 450 |     | mA   |  |  |
| BBM time via internal delay (start      | tввмо                                                  | BBMCLKS=0     | 75  | 100 |     | ns   |  |  |
| of gate switching off to start of       |                                                        | BBMTIME=0     |     |     |     |      |  |  |
| gate switching on)                      | t <sub>BBM16</sub>                                     | BBMTIME=16    |     | 200 |     | ns   |  |  |
|                                         | t <sub>BBM16</sub>                                     | BBMTIME=24    |     | 375 | 500 | ns   |  |  |
|                                         | ELECTBONIC                                             |               |     |     |     |      |  |  |

| Charge pump                                              | DC-Characteristics                |                                                |                            |                             |     |      |  |
|----------------------------------------------------------|-----------------------------------|------------------------------------------------|----------------------------|-----------------------------|-----|------|--|
| Parameter                                                | Symbol                            | Conditions                                     | Min                        | Тур                         | Max | Unit |  |
| Charge pump output voltage                               | V <sub>VCP</sub> -V <sub>VS</sub> | operating                                      | V <sub>12VOUT</sub> -<br>2 | V <sub>12VOUT</sub> -<br>1  |     | V    |  |
| Charge pump voltage threshold for undervoltage detection | V <sub>VCP</sub> -V <sub>VS</sub> | rising, using internal<br>5V regulator voltage | 4.5                        | 5                           | 6.5 | V    |  |
| Charge pump frequency                                    | f <sub>CP</sub>                   |                                                |                            | 1/16<br>f <sub>clkosc</sub> |     |      |  |

www.trinamic.com

| Linear regulator                                                  | DC-Characteristics       |                                                                                               |      |       |        |             |  |
|-------------------------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------|------|-------|--------|-------------|--|
|                                                                   | $V_{VS} = V_{VSA}$       | = 24.0V                                                                                       |      |       |        |             |  |
| Parameter                                                         | Symbol                   | Conditions                                                                                    | Min  | Тур   | Max    | Unit        |  |
| Output voltage                                                    | V <sub>5VOUT</sub>       | T <sub>J</sub> = 25°C                                                                         | 4.80 | 5.0   | 5.20   | V           |  |
| Deviation of output voltage over<br>the full temperature range    | V <sub>5VOUT</sub> (DEV) | drivers disabled<br>TJ = full range                                                           |      | +/-30 | +/-100 | mV          |  |
| Deviation of output voltage over<br>the full supply voltage range | V <sub>5VOUT</sub> (Dev) | drivers disabled,<br>internal clock<br>T <sub>A</sub> = 25°C<br>V <sub>VSA</sub> = 10V to 30V |      |       | +/-50  | mV /<br>10V |  |
| Output voltage                                                    | V <sub>12VOUT</sub>      | operating, internal<br>clock<br>TJ = 25°C                                                     | 10.8 | 11.5  | 12.2   | V           |  |

| Clock oscillator and input                                            | Timing-Cl                  | naracteristics                | de la compañía de la |       |      |                     |
|-----------------------------------------------------------------------|----------------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|---------------------|
| Parameter                                                             | Symbol                     | Symbol Conditions             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Тур   | Max  | Unit                |
| Clock oscillator frequency                                            | f <sub>CLKOSC</sub>        | tj=-50°C                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 11.7  |      | MHz                 |
| (factory calibrated)                                                  | <b>f</b> <sub>CLKOSC</sub> | tj=50°C                       | 11.5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 12.0  | 12.5 | MHz                 |
|                                                                       | f <sub>CLKOSC</sub>        | tj=150°C                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 12.1  |      | MHz                 |
| External clock frequency                                              | f <sub>CLK</sub>           |                               | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 10-16 | 18   | MHz                 |
| (operating)                                                           |                            |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |                     |
| External clock high / low level                                       | t <sub>CLKH</sub> /        | CLK driven to                 | 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      | ns                  |
| time                                                                  | t <sub>CLKL</sub>          | $0.1 V_{VIO}$ / $0.9 V_{VIO}$ |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |                     |
| External clock first pulse to                                         | t <sub>CLKH</sub> /        | CLK driven high               | 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |      | ns                  |
| trigger switching to external CLK                                     | tclkl                      | A-version                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |                     |
| External clock first pulse to                                         | t <sub>clkh</sub> /        | CLK driven high               | 30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 25    |      | ns                  |
| trigger switching to external CLK                                     | <b>t</b> CLKL              | non-A-version only            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      |                     |
| External clock timeout detection t <sub>CLKH1</sub>                   |                            | CLK driven high               | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       | 48   | cycles              |
| in cycles of internal f <sub>CLKOSC</sub>                             |                            |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |      | f <sub>CLKOSC</sub> |
| trigger switching to external CLK<br>External clock timeout detection | <b>t</b> CLKL              | non-A-version only            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 25    | 48   | cycles              |

| Short detection                | DC-Characteristics |               |      |       |      |      |  |
|--------------------------------|--------------------|---------------|------|-------|------|------|--|
| Parameter                      | Symbol             | Conditions    | Min  | Тур   | Max  | Unit |  |
| Short to GND / Short to VS     | t <sub>SD0</sub>   | FILT_ISENSE=0 | 0.5  | 0.85  | 1.1  | μs   |  |
| detector delay (Start of gate  |                    | S2xx_LEVEL=6  |      |       |      |      |  |
| switch on to short detected)   |                    | shortdelay=0  |      |       |      |      |  |
| Including 100ns filtering time | tsdi               | shortdelay=1  | 1.1  | 1.6   | 2.2  | μs   |  |
| Short detector level S2VS      | V <sub>BM</sub>    | S2VS_LEVEL=15 | 1.4  | 1.56  | 1.72 | V    |  |
| (measurement includes drop in  |                    | S2VS_LEVEL=6  | 0.55 | 0.625 | 0.70 | V    |  |
| sense resistor)                |                    |               |      |       |      |      |  |
| Short detector level S2G       | $V_{S}$ - $V_{BM}$ | S2G_LEVEL=15; | 1.2  | 1.56  | 1.9  | V    |  |
|                                |                    | VS<52V        |      |       |      |      |  |
|                                |                    | S2G_LEVEL=15; | 0.85 |       |      | V    |  |
|                                |                    | VS<55V        |      |       |      |      |  |
|                                |                    | S2G_LEVEL=6;  | 0.46 | 0.625 | 0.80 | V    |  |
|                                |                    | VS<50V        |      |       |      |      |  |

www.trinamic.com

# published by WWW.SKYTECH.IR

| Detector levels                                              | DC-Characteristics      |                                                 |     |     |     |      |  |
|--------------------------------------------------------------|-------------------------|-------------------------------------------------|-----|-----|-----|------|--|
| Parameter                                                    | Symbol                  | Conditions                                      | Min | Тур | Max | Unit |  |
| V <sub>VSA</sub> undervoltage threshold for RESET            | V <sub>UV_VSA</sub>     | V <sub>VSA</sub> rising                         | 3.6 | 4   | 4.6 | V    |  |
| $V_{\mbox{\tiny SVOUT}}$ undervoltage threshold for RESET    | V <sub>UV_5VOUT</sub>   | V <sub>svout</sub> rising                       |     | 3.5 |     | V    |  |
| $V_{\text{VCC}\_\text{IO}}$ undervoltage threshold for RESET | V <sub>UV_VIO</sub>     | V <sub>vcc_I0</sub> rising (delay<br>typ. 10µs) | 2.0 | 2.5 | 3.0 | V    |  |
| V <sub>VCC_IO</sub> undervoltage detector hysteresis         | V <sub>UV_VIOHYST</sub> |                                                 |     | 0.3 |     | V    |  |
| Overtemperature prewarning<br>120°C                          | T <sub>otpw</sub>       | Temperature rising                              | 100 | 120 | 140 | °C   |  |
| Overtemperature shutdown<br>136 °C                           | T <sub>0T136</sub>      | Temperature rising                              |     | 136 |     | °C   |  |
| Overtemperature shutdown<br>143 °C                           | T <sub>0T143</sub>      | Temperature rising                              |     | 143 |     | °C   |  |
| Overtemperature shutdown<br>150 °C                           | Тотібо                  | Temperature rising                              | 135 | 150 | 170 | °C   |  |

| Sense resistor voltage levels                                                                      | DC-Characteristics<br>f <sub>CLK</sub> =16MHz |                                                                             |     |     |     |      |
|----------------------------------------------------------------------------------------------------|-----------------------------------------------|-----------------------------------------------------------------------------|-----|-----|-----|------|
| Parameter                                                                                          | Symbol                                        | Conditions                                                                  | Min | Тур | Max | Unit |
| Sense input peak threshold<br>voltage (low sensitivity)<br>(V <sub>SRxH</sub> -V <sub>SRxL</sub> ) | V <sub>SRT</sub>                              | GLOBALSCALER=0<br>csactual=31<br>sin_x=248<br>Hyst.=0; I <sub>BRxy</sub> =0 |     | 325 |     | mV   |
| Sense input tolerance / motor<br>current full scale tolerance<br>-using internal reference         | I <sub>con</sub>                              | GLOBALSCALER=0                                                              | -5  |     | +5  | %    |

| Digital pins                     | al pins DC-Characteristics       |                          |                        |                          | e la compañía de la compa |      |
|----------------------------------|----------------------------------|--------------------------|------------------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Parameter                        | Symbol                           | Conditions               | Min                    | Тур                      | Max                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Unit |
| Input voltage low level          | VINLO                            |                          | -0.3                   |                          | $0.3 \ V_{\text{VIO}}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | V    |
| Input voltage high level         | $V_{\text{INHI}}$                |                          | $0.7 \ V_{\text{VIO}}$ |                          | V <sub>VI0</sub> +0.3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | V    |
| Input Schmitt trigger hysteresis | VINHYST                          |                          |                        | 0.12<br>V <sub>VIO</sub> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | V    |
| Output voltage low level         | VOUTLO                           | I <sub>OUTLO</sub> = 2mA |                        |                          | 0.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | V    |
| Output voltage high level        | VOUTHI                           | IOUTHI = -2mA            | V <sub>VI0</sub> -0.2  |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | V    |
| Input leakage current            | I <sub>ILEAK</sub>               | ELEC                     | -10                    |                          | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | μA   |
| Pullup / pull-down resistors     | R <sub>PU</sub> /R <sub>PD</sub> | ELEU                     | 132                    | 166                      | 200                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | kΩ   |
| Digital pin capacitance          | С                                |                          |                        | 3.5                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | рF   |

### **28.3 Thermal Characteristics**

The following table shall give an idea on the thermal resistance of the package. The thermal resistance for a four layer board will provide a good idea on a typical application. Actual thermal characteristics will depend on the PCB layout, PCB type and PCB size. The thermal resistance will benefit from thicker CU (inner) layers for spreading heat horizontally within the PCB. Also, air flow will reduce thermal resistance.

www.trinamic.com

| Parameter                                                    | Symbol            | Conditions                                                                                                                                            | Тур | Unit |
|--------------------------------------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|
| Typical power dissipation                                    | P <sub>D</sub>    | StealthChop or SpreadCycle, 40 or<br>20kHz chopper, 24V, internal supply<br>regulators                                                                | 0.6 | W    |
| Thermal resistance junction to ambient on a multilayer board | R <sub>tmja</sub> | Dual signal and two internal power<br>plane board (2s2p) as defined in<br>JEDEC EIA JESD51-5 and JESD51-7<br>(FR4, 35µm CU, 70mm x 133mm,<br>d=1.5mm) | 21  | K/W  |
| Thermal resistance junction to board                         | R <sub>tjb</sub>  | PCB temperature measured within<br>1mm distance to the package leads                                                                                  | 8   | K/W  |
| Thermal resistance junction to case                          | Rtjc              | Junction temperature to heat slug of package                                                                                                          | 3   | K/W  |

#### Table 28.1 Thermal characteristics TQFP48-EP

The thermal resistance in an actual layout can be tested by checking for the heat up caused by the standby power consumption of the chip. When no motor is attached, all power seen on the power supply is dissipated within the chip.



www.trinamic.com

### **29** Layout Considerations

#### 29.1 Exposed Die Pad

The TMC5160 uses its die attach pad to dissipate heat from the gate drivers and the linear regulator to the board. For best electrical and thermal performance, use a reasonable amount of solid, thermally conducting vias between the die attach pad and the ground plane. The printed circuit board should have a solid ground plane spreading heat into the board and providing for a stable GND reference.

#### 29.2 Wiring GND

All signals of the TMC5160 are referenced to their respective GND. Directly connect all GND pins under the device to a common ground area (GND, GNDP, GNDA and die attach pad). The GND plane right below the die attach pad should be treated as a virtual star point. For thermal reasons, the PCB top layer shall be connected to a large PCB GND plane spreading heat within the PCB.

Attention

Place the TMC5160 near to the MOSFET bridge and sense resistor GND in order to avoid ringing leading to GND differences and to dangerous inductive peak voltages.

#### 29.3 Wiring Bridge Supply

The power bridge will draw the full coil current in pulses with extremely high dI/dt. Thus, any inductivity between VS supply filtering and the MOSFETs can lead to severe voltage spikes. This has to be avoided. Avoid any bend in the supply traces between filtering capacitors and MOSFET switches, and keep distance as small as possible. Especially for high current, use a separate plane for the supply voltage, and a sufficient number and capacity for supply filtering. Use an additional capacitor for the IC VS pin, as additional ripple voltage would cause severe current spikes on the charge pump capacitor. A tiny series resistor can be added to avoid this.

#### Attention

Keep supply voltage ripple low, by using sufficient filtering capacity close to the MOSFET bridge.

#### 29.4 Supply Filtering

The 5VOUT output voltage ceramic filtering capacitor (2.2 to 4.7  $\mu$ F recommended) should be placed as close as possible to the 5VOUT pin, with its GND return going directly to the GNDA pin. This ground connection shall not be shared with other loads or additional vias to the GND plane. Use as short and as thick connections as possible. For best microstepping performance and lowest chopper noise an additional filtering capacitor should be used for the VCC pin to GND, to avoid digital part ripple influencing motor current regulation. Therefore, place a ceramic filtering capacitor (470nF recommended) as close as possible (1-2mm distance) to the VCC pin with GND return going to the ground plane. VCC can be coupled to 5VOUT using a 2.2  $\Omega$  or 3.3  $\Omega$  resistor in order to supply the digital logic from 5VOUT while keeping ripple away from this pin. A 100 nF filtering capacitor should be placed as close as possible to the VSA pin to ground plane. Make sure, that VS does not see excessive voltage spikes caused by bridge operation and place a 100 nF or larger filter capacitor to GND close to the VS pin.

Please carefully read chapters 3.3 and 3.4 to understand the special considerations with regard to layout and component selection for the external MOSFET power bridges.

www.trinamic.com

### 29.5 Layout Example

#### Schematic (TMC5160+MOSFETs shown)



www.trinamic.com



Figure 29.1 Layout example

When using the TQFP package in designs for more than 30V consider PCB coating to satisfy sufficient creeping distances.

www.trinamic.com

Hint

### 30 Package Mechanical Data

#### 30.1 Dimensional Drawings TQFP48-EP

Drawings not to scale.



Figure 30.1 Dimensional drawings TQFP48-EP

www.trinamic.com

| Parameter                         | Ref | Min  | Nom   | Max  |
|-----------------------------------|-----|------|-------|------|
| total thickness                   | Α   | -    | -     | 1.2  |
| stand off                         | A1  | 0.05 | -     | 0.15 |
| mold thickness                    | A2  | 0.95 | 1     | 1.05 |
| lead width (plating)              | b   | 0.17 | 0.22  | 0.27 |
| lead width                        | b1  | 0.17 | 0.2   | 0.23 |
| lead frame thickness<br>(plating) | c   | 0.09 | -     | 0.2  |
| lead frame thickness              | c1  | 0.09 | -     | 0.16 |
| body size X (over pins)           | D   |      | 9.0   |      |
| body size Y (over pins)           | E   |      | 9.0   |      |
| body size X                       | D1  |      | 7.0   |      |
| body size Y                       | E1  |      | 7.0   |      |
| lead pitch                        | e   |      | 0.5   |      |
| lead                              | L   | 0.45 | 0.6   | 0.75 |
| footprint                         | L1  |      | 1 REF |      |
|                                   | Θ   | 0°   | 3.5°  | 7°   |
|                                   | Θ1  | 0°   | -     | -    |
|                                   | Θ2  | 11°  | 12°   | 13°  |
|                                   | Θ3  | 11°  | 12°   | 13°  |
|                                   | R1  | 0.08 | -     | -    |
|                                   | R2  | 0.08 | -     | 0.2  |
|                                   | S   | 0.2  |       | -    |
| exposed die pad size X            | М   | 4.9  | 5     | 5.1  |
| exposed die pad size Y            | Ν   | 4.9  | 5     | 5.1  |
| package edge tolerance            | aaa |      |       | 0.2  |
| lead edge tolerance               | bbb |      |       | 0.2  |
| coplanarity                       | ccc |      |       | 0.08 |
| lead offset                       | ddd |      |       | 0.08 |
| mold flatness                     | eee |      |       | 0.05 |

SKIELECTRONIC

www.trinamic.com



### 30.2 Dimensional Drawings QFN-WA

Figure 30.2 Dimensional drawings wettable QFN

www.trinamic.com

| Parameter              | Ref | Min   | Nom   | Max   |
|------------------------|-----|-------|-------|-------|
| total thickness        | Α   | 0.8   | 0.85  | 0.9   |
| stand off              | A1  | 0     | 0.035 | 0.05  |
| mold thickness         | A2  |       | 0.65  |       |
| lead frame thickness   | A3  |       | 0.203 |       |
| lead width             | b   | 0.2   | 0.25  | 0.3   |
| body size X            | D   |       | 8.0   |       |
| body size Y            | E   |       | 8.0   |       |
| lead pitch             | e   |       | 0.5   |       |
| exposed die pad size X | J   | 6.15  | 6.25  | 6.35  |
| exposed die pad size Y | К   | 6.15  | 6.25  | 6.35  |
| lead length            | L   | 0.35  | 0.4   | 0.45  |
| lead length            | L1  | 0.3   | 0.4   | 0.45  |
| package edge tolerance | aaa |       | 0.1   |       |
| mold flatness          | bbb |       | 0.1   |       |
| coplanarity            | ccc |       | 0.08  |       |
| lead offset            | ddd | 0.1   |       |       |
| exposed pad offset     | eee | 0.1   |       |       |
| half-cut depth         | R   | 0.075 |       |       |
| half-cut depth         | S   |       |       | 0.075 |

## 30.3 Package Codes

| Туре        | Package                                       | Temperature range          | Code & marking |  |  |
|-------------|-----------------------------------------------|----------------------------|----------------|--|--|
| TMC5160A-TA | TQFP-EP48 (RoHS)                              | -40°C +1 <mark>25°C</mark> | TMC5160A-TA    |  |  |
| TMC5160A-WA | QFN8x8 wettable                               | -40°C +125°C               | TMC5160A-WA    |  |  |
| Т           | T denotes tape on reel packing (order option) |                            |                |  |  |



www.trinamic.com

### 31 Design Philosophy

The TMC50XX and TMC51XX family brings premium functionality, reliability and coherence previously reserved to costly motion control units to smart applications. Integration at street level cost was possible by squeezing know-how into a few mm<sup>2</sup> of layout using one of the most modern smart power processes. The ICs comprise all the knowledge gained from designing motion controller and driver chips and complex motion control systems for more than 20 years. We are often asked if our motion controllers contain software – they definitely do not. The reason is that sharing resources in software leads to complex timing constraints and can create interrelations between parts which should not be related. This makes debugging of software so difficult. Therefore, the IC is completely designed as a hardware solution, i.e. each internal calculation uses a specially designed dedicated arithmetic unit. The basic philosophy is to integrate all real-time critical functionality in hardware, and to leave additional starting points for highest flexibility. Parts of the design go back to previous ICs, starting from the TMC453 motion controller developed in 1997. Our deep involvement, practical testing and the stable team ensure a high level of confidence and functional safety.

Bernhard Dwersteg, CTO and founder

### 32 Disclaimer

TRINAMIC Motion Control GmbH & Co. KG does not authorize or warrant any of its products for use in life support systems, without the specific written consent of TRINAMIC Motion Control GmbH & Co. KG. Life support systems are equipment intended to support or sustain life, and whose failure to perform, when properly used in accordance with instructions provided, can be reasonably expected to result in personal injury or death.

Information given in this data sheet is believed to be accurate and reliable. However, no responsibility is assumed for the consequences of its use nor for any infringement of patents or other rights of third parties which may result from its use.

Specifications are subject to change without notice. All trademarks used are property of their respective owners.

### 33 ESD Sensitive Device

The TMC5160 is an ESD sensitive CMOS device sensitive to electrostatic discharge. Take special care to use adequate grounding of personnel and machines in manual handling. After soldering the devices to the board, ESD requirements are more relaxed. Failure to do so can result in defect or decreased reliability.

ELECTRONI



### 34 Designed for Sustainability

Sustainable growth is one of the most important and urgent challenges today. We at Trinamic try to contribute by designing highly efficient IC products, to minimize energy consumption, ensure best customer experience and long-term satisfaction by smooth and silent run, while minimizing the demand for external resources, e.g. for power supply, cooling infrastructure, reduced motor size and magnet material by intelligent control interfaces and advanced algorithms.

Please help and design efficient and durable products made for a sustainable world.

www.trinamic.com

## 35 Table of Figures

| FIGURE 1.1 TMC5160 BASIC APPLICATION BLOCK DIAGRAM (MOTION CONTROLLER)                                                                                                |    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| FIGURE 1.2 TMC5160 STEP/DIR APPLICATION DIAGRAM                                                                                                                       |    |
| FIGURE 1.3 TMC5160 STANDALONE DRIVER APPLICATION DIAGRAM                                                                                                              |    |
| FIGURE 1.4 AUTOMATIC MOTOR CURRENT POWER DOWN<br>FIGURE 1.5 ENERGY EFFICIENCY WITH COOLSTEP (EXAMPLE)                                                                 |    |
| FIGURE 1.5 ENERGY EFFICIENCY WITH COULSTEP (EXAMPLE)<br>FIGURE 2.1 TMC5160-TA PACKAGE AND PINNING TQFP-EP 48 (7X7MM <sup>2</sup> BODY, 9X9MM <sup>2</sup> WITH LEADS) |    |
| FIGURE 2.2 TMC5160-TA PACKAGE AND PINNING TQFF-EF 48 (7X7MM2 BODY, 9X9MM2 WITH LEADS)                                                                                 |    |
| FIGURE 3.1 STANDARD APPLICATION CIRCUIT                                                                                                                               |    |
| FIGURE 3.2 EXTERNAL GATE VOLTAGE SUPPLY                                                                                                                               |    |
| FIGURE 3.3 MILLER CHARGE DETERMINES SWITCHING SLOPE                                                                                                                   |    |
| FIGURE 3.4 SLOPES, MILLER PLATEAU AND BLANK TIME                                                                                                                      |    |
| FIGURE 3.5 BRIDGE PROTECTION OPTIONS FOR POWER ROUTING INDUCTIVITY.                                                                                                   |    |
| FIGURE 3.6 RINGING OF OUTPUT (BLUE) AND GATE VOLTAGES (YELLOW, CYAN) WITH UNTUNED BRIGE                                                                               |    |
| FIGURE 3.7 SWITCHING EVENT WITH OPTIMIZED COMPONENTS (WITHOUT / AFTER BULK DIODE CONDUCTION)                                                                          |    |
| FIGURE 3.8 EXAMPLE FOR BRIDGE WITH TUNED COMPONENTS (SEE SCOPE SHOTS)                                                                                                 |    |
| FIGURE 3.9 EXTERNAL GATE DRIVER EXAMPLE                                                                                                                               |    |
| FIGURE 4.1 SPI TIMING                                                                                                                                                 | 25 |
| FIGURE 5.1 ADDRESSING MULTIPLE TMC5160 VIA SINGLE WIRE INTERFACE USING CHAINING                                                                                       |    |
| FIGURE 5.2 ADDRESSING MULTIPLE TMC5160 VIA THE DIFFERENTIAL INTERFACE, ADDITIONAL FILTERING FOR NAI                                                                   | 30 |
| FIGURE 7.1 MOTOR COIL SINE WAVE CURRENT WITH STEALTHCHOP (MEASURED WITH CURRENT PROBE)                                                                                |    |
| FIGURE 7.2 STEALTHCHOP2 AUTOMATIC TUNING PROCEDURE                                                                                                                    | 59 |
| FIGURE 7.3 SCOPE SHOT: GOOD SETTING FOR PWM_REG                                                                                                                       | 61 |
| FIGURE 7.4 SCOPE SHOT: TOO SMALL SETTING FOR PWM_REG DURING AT#2                                                                                                      | 61 |
| FIGURE 7.5 SUCCESSFULLY DETERMINED PWM_GRAD(_AUTO) AND PWM_OFS(_AUTO)                                                                                                 | 61 |
| FIGURE 7.6 VELOCITY BASED PWM SCALING (PWM_AUTOSCALE=0)                                                                                                               |    |
| FIGURE 7.7 TPWMTHRS FOR OPTIONAL SWITCHING TO SPREADCYCLE                                                                                                             | 65 |
| FIGURE 8.1 CHOPPER PHASES                                                                                                                                             |    |
| FIGURE 8.2 NO LEDGES IN CURRENT WAVE WITH SUFFICIENT HYSTERESIS (MAGENTA: CURRENT A, YELLOW & BLUE: SENSI                                                             |    |
| RESISTOR VOLTAGES A AND B)                                                                                                                                            |    |
| FIGURE 8.3 SPREADCYCLE CHOPPER SCHEME SHOWING COIL CURRENT DURING A CHOPPER CYCLE                                                                                     |    |
| FIGURE 8.4 CLASSIC CONST. OFF TIME CHOPPER WITH OFFSET SHOWING COIL CURRENT                                                                                           |    |
| FIGURE 8.5 ZERO CROSSING WITH CLASSIC CHOPPER AND CORRECTION USING SINE WAVE OFFSET                                                                                   |    |
| FIGURE 10.1 CHOICE OF VELOCITY DEPENDENT MODES                                                                                                                        |    |
| FIGURE 11.1 SHORT DETECTION                                                                                                                                           |    |
| FIGURE 12.1 RAMP GENERATOR VELOCITY TRACE SHOWING CONSEQUENT MOVE IN NEGATIVE DIRECTION                                                                               |    |
| FIGURE 12.2 ILLUSTRATION OF OPTIMIZED MOTOR TORQUE USAGE WITH TMC5160 RAMP GENERATOR                                                                                  |    |
| FIGURE 12.3 RAMP GENERATOR VELOCITY DEPENDENT MOTOR CONTROL                                                                                                           |    |
| FIGURE 12.4 USING REFERENCE SWITCHES (EXAMPLE)                                                                                                                        | 85 |
|                                                                                                                                                                       |    |
| FIGURE 13.2 EXAMPLE: OPTIMUM SGT SETTING AND STALLGUARD2 READING WITH AN EXAMPLE MOTOR                                                                                |    |
| FIGURE 14.1 COOLSTEP ADAPTS MOTOR CURRENT TO THE LOAD                                                                                                                 |    |
| FIGURE 15.2 MICROPLYER MICROSTEP INTERPOLATION WITH RISING STEP FREQUENCY (EXAMPLE: 16 TO 256)                                                                        |    |
| FIGURE 15.2 MICROFLYER MICROFLYER MICROFLY INTERPOLATION WITH RISING STEP FREQUENCY (EXAMPLE: 16 TO 256)                                                              |    |
| FIGURE 16.2 DIAG OUTPUTS WITH SD_MODE=0                                                                                                                               |    |
| FIGURE 17.1 DCSTEP EXTENDED APPLICATION OPERATION AREA                                                                                                                |    |
| FIGURE 17.2 VELOCITY PROFILE WITH IMPACT BY OVERLOAD SITUATION                                                                                                        |    |
| FIGURE 17.3 MOTOR MOVING SLOWER THAN STEP INPUT DUE TO LIGHT OVERLOAD. LOSTSTEPS INCREMENTED                                                                          |    |
| FIGURE 17.4 FULL SIGNAL INTERCONNECTION FOR DCSTEP                                                                                                                    |    |
| FIGURE 17.5 DCO INTERFACE TO MOTION CONTROLLER – STEP GENERATOR STOPS WHEN DCO IS ASSERTED                                                                            |    |
| FIGURE 18.1 LUT PROGRAMMING EXAMPLE                                                                                                                                   |    |
| FIGURE 20.1 OUTLINE OF ABN SIGNALS OF AN INCREMENTAL ENCODER                                                                                                          |    |
| FIGURE 22.1 CURRENT SETTING AND FIRST STEPS WITH STEALTHCHOP                                                                                                          |    |
| FIGURE 22.2 TUNING STEALTHCHOP AND SPREADCYCLE                                                                                                                        |    |
|                                                                                                                                                                       |    |

www.trinamic.com

| FIGURE 22.3 MOVING THE MOTOR USING THE MOTION CONTROLLER                                    | 113 |
|---------------------------------------------------------------------------------------------|-----|
| FIGURE 22.4 ENABLING COOLSTEP (ONLY IN COMBINATION WITH SPREADCYCLE)                        | 114 |
| FIGURE 22.5 SETTING UP DCSTEP                                                               | 115 |
| FIGURE 24.1 STANDALONE OPERATION WITH TMC5160 (PINS SHOWN WITH THEIR STANDALONE MODE NAMES) | 117 |
| FIGURE 29.1 LAYOUT EXAMPLE                                                                  | 127 |
| FIGURE 30.1 DIMENSIONAL DRAWINGS TQFP48-EP                                                  | 128 |
| FIGURE 30.2 DIMENSIONAL DRAWINGS WETTABLE QFN                                               | 130 |

### **36 Revision History**

| Version | Date        | Author<br>BD= Bernhard Dwersteg | Description                                                                                                                            |
|---------|-------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| V0.14   | 2017-APR-13 | BD                              | First version of datasheet based on datasheet TMC5130 V1.13.                                                                           |
| V0.15   | 2017-APR-28 | BD                              | Added QFN package and product picture                                                                                                  |
| V0.9    | 2017-MAY-04 | BD                              | Added new EVAL layout screenshots                                                                                                      |
| V0.91   | 2017-MAY-15 | BD                              | Adapted pinning for QFN wettable package (47 pins!), added preliminary package dimensions                                              |
| V0.92   | 2017-MAY-31 | BD                              | Added hints for automatic tuning process.                                                                                              |
| V0.93   | 2017-SEP-07 | BD                              | Some text enhancements, higher operating voltage limit                                                                                 |
| V0.94   | 2017-SEP-14 | BD                              | UV VCCIO $\rightarrow$ 2V min.                                                                                                         |
| V1.00   | 2017-NOV-18 | BD                              | Link corrected, OTP read table addr. corr.<br>Reduced peak operation voltage limits<br>Added some Attention boxes or converted to Hint |
| V1.01   | 2017-NOV-29 | BD                              | S2G detector thresholds fixed for final product, Corrected TPFD time formula                                                           |
| V1.02   | 2017-DEZ-14 | BD                              | SWIOP/N → SWP/N, CFG6 errata                                                                                                           |
| V1.04   | 2018-MAY-02 | BD                              | Exchanged Title graphics for -WA, minor fixes of text.                                                                                 |
| V1.06   | 2018-JUN-06 | BD                              | Added errata / limitations for initial tuning of AT#1 / AT#2 phase                                                                     |
| V1.07   | 2018-OCT-18 | BD                              | Corrected 52V and 55V limits for S2GND detector, minor corrections                                                                     |
| V1.08   | 2018-NOV-19 | BD                              | Added hints for tuning MOSFET bridge, added wiring bridge supply                                                                       |
| V1.10   | 2019-FEB-05 | BD                              | Corrected timing requirements for CLK input (30ns for first pulse) / some minor fixes                                                  |
| V1.11   | 2019-JUN-07 | BD                              | Minor wording, hint on coating, added order codes                                                                                      |
| V1.12   | 2019-AUG-05 | BD                              | Added changes for TMC5160A, Errata for DIAG output in standalone mode                                                                  |
| V1.13   | 2019-NOV-19 | BD                              | Minor changes, added high voltage example                                                                                              |

Table 36.1 Document Revisions

### **37 References**

[TMC5160-EVAL] TMC5160-EVAL Evaluation Board
[AN001] Trinamic Application Note 001 - Parameterization of SpreadCycle<sup>™</sup>, www.trinamic.com
[AN002] Trinamic Application Note 002 - Parameterization of StallGuard2<sup>™</sup> & CoolStep<sup>™</sup>, www.trinamic.com
[AN003] Trinamic Application Note 003 - DcStep<sup>™</sup>, www.trinamic.com

Calculation sheet TMC5160\_Calculations.xlsx

www.trinamic.com